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© Modular unitary disk file subsystem. 



© A modular unitary disk file subsystem is dis- 
closed for use directly with a host computer. The 
subsystem includes a common unitary mounting 
substrate for signal connections to the host and for 
supplying signals back via data, address and control 
buses the host computer through a direct plug-in 
^connection without any cabling between the sub- 
^ system and the host The substrate carries and 
interconnects a unitary disk store head and disk 
^assembly, a disk store control, a disk file controller, 
f^and a data and control interface with the computer. 

The modular unitary plug-in form factor, a single 
^ supervisory microcomputer controller and a memory 
C\j containing basic input/output driver routines directly 
_ executable by the host computer are aspects of the 
present invention. 

CL 
UJ 




FIG I 



Xerox Copy Centre 



1 



0 204 299 



2 



MODULAR UNITARY DISK RLE SUBSYSTEM 



Field of the Invention 

The present invention relates to rotating disk 
data storage peripheral equipment for digital com- 
puters. More particularly, the present invention re- 5 
lates to a miniaturized, plug-in rotating fixed disk 
file subsystem module. 

Background of the Invention 

10 

Disk drives (also known as disk files) have 
become standard equipment for storing and retriev- 
ing user data in both large and small digital com- 
puter systems- Such drives have used removable 
rigid, semi-rigid and flexible disks e.g. coated with 75 
magnetic media for storing the data. Optical data 
storage techniques are also known. 

Disk drives of the type employed by the 
present invention have also used non-removable 
rotating storage disks in sealed, dust free environ- 20 
ments in which the data transducers fly very close 
to the storage surface on an air cushion or bearing 
in accordance with what is known as "Winchester" 
technology. These disk drives store and retrieve 
data in concentric data tracks formed on the major 25 
surfaces of the data storage disk. Such non-remov- 
able or "fixed" disk based drives are able to store 
a significant amount of user data on each storage 
surface, such as five million bytes of user data per 
storage surface. - 30 

By moving the data transducers radially rela- 
tive to the rotating disks with electromagnetic disk 
actuator mechanisms, disk drives are able to gain 
access to any data location within a very short 
period of time. Thus, such drives combine the 35 
features of substantial data storage capacity and 
random rapid access to any selected concentric 
track containing the stored data. 

Traditionally, disk drives have been bulky and 
have required multiple separate subparts: an en- 40 
closed head and disk assembly; control electronics 
for the head and disk assembly, usually packaged 
with the head and disk assembly, a controller for 
controlling the formatting of the data storage sur- 
face and for thereafter controlling each data stor- 45 
age (write) and retrieval (read) operation performed 
by the drive; and an interface, for interfacing both 
the controller and the drive control electronics to 
the host computer, so that its operating system 
may use the drive effectively as a data storage so 
resource available to the computer user. 

Small computer systems, sometimes referred 
to as "persona) computers" and as exemplified by 
the IBM Personal Computer 1 ™, typically provide 
attachment locations and electrical connections for 



a few accessory circuit cards. These accessory 
cards may provide disk drive controller, video dis- 
play, modem, additional memory, and other func- 
tions. Usually the space allocated for such acces- 
sory cards is narrow (one inch across) and elon- 
gated. Also, the power supply available for such 
additional accessories is quite limited. 

One significant drawback of the traditional ap- 
proach has been that the use of separate circuits 
for the control electronics, controller and interface 
has led to redundancies of circuitry, particularly 
control, address and data buffers, and consequent 
high power consumption levels. These power con- 
sumption levels have required host computer sys- 
tems to be designed to supply the required higher 
levels, or have required separate or special power 
supplies to be used. 

One other significant drawback of the tradi- 
tional approach has been the physical space re- 
quired to house the head and disk assembly, its 
control electronics, the controller and the interface. 
When separate housings have been employed, sig- 
nificant drawbacks have been the clutter presented 
by the multiple housings and requirement that 
housings be cabled together with cables carrying a 
large number of conductors. Such cablings and 
plugs, extending outside of the housings, are ex- 
posed and have been known to fail, thereby ren- 
dering the disk drive subsystem inoperative and 
useless until repaired. Also, multiple housings have 
complicated the portability of small personal com- 
puter systems. 

Fixed disk drive head and disk assemtfies do 
not lend themselves to home or field repairs. The 
disk drive enclosure may only be opened safely for 
inspection and service in a "clean-room" environ- 
ment Thus, the servicing of small fixed disk files 
usually goes on in the factory or at one or a few 
central service locations. 

In light of these and other drawbacks known to 
those skilled in the art, a hitherto unsolved need 
has arisen for a fully integrated, highly miniatur- 
ized, very low power rotating non removable disk 
data storage subsystem module for direct plug-in 
attachment to and use within small host computer 
systems, typically of the "personal or professional 
computer? (single user) type, without use of any 
cabling and without any modification of the host 
beyond plugging in the modular subsystem. 
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Summary of the Invention with Objects 

A general object of the present invention is to 
miniaturize and to integrate a complete disk file 
subsystem into a small unitary module for direct 
plug-in attachment to and removal from a host 
computer system in a manner which overcomes 
the limitations and drawbacks of prior art disk file 
subsystems. 

A specific object of the present invention is to 
provide a miniaturized, fully integrated disk drive 
subsystem in a flat, elongated form factor for plug- 
in attachment to a single user computer so as to 
occupy a single accessory jack location provided in 
the computer for attachment of accessories. 

A further object of the present invention is to 
provide a miniaturized and fully self contained uni- 
tary disk file subsystem for direct plug-in attach- 
ment to a host computer of the single user type 
without requiring any hardware modification of the 
computer. 

One more object of the present invention is to 
provide a miniaturized and fully self contained uni- 
tary disk file subsystem which may be plugged into 
and used with a host computer of the single user 
type by the computer user without requiring any 
special skills or special tools for the installation or 
for use. 

A further object of the present invention is to 
provide a compact and efficient electronic control 
system which uses a single microprocessor to su- 
pervise operations of the disk file. 

A modular unitary disk file subsystem for a 
host computer incorporating the principles of the 
present invention includes a thin, compact, and 
enclosed radially movable head and fixed rotating 
disk assembly. An elongated, planar support sub- 
strate is provided for mounting and supporting the 
head and disk assembly and for mounting, carrying 
and connecting electronic circuit elements for mov- 
ing the head radially relative to the disk. The elec- 
tronic circuit elements are provided for controlling 
data storage operations for storing and retrieving 
data from among selected concentric data tracks 
formed on a data storage surface of the fixed 
rotating disk through the head, and for interfacing 
the disk file subsystem with the host computer. 
The support substrate further includes a connector 
at a single location thereon, the connector being 
provided for obtaining power, control and data sig- 
nals from the host computer, and for supplying 
control, status and data signals to the host com- 
puter. Thus, the support substrate thereby carries 
and interconnects the subsystem with the host 
computer as a direct plug-in unit within the housing 
of the host, without any cabling between the host 
and the subsystem. 



These and other objects, advantages and fea- 
tures of the present invention will become more 
apparent from the following detailed description of 
a preferred embodiment, presented in conjunction 
5 with the accompanying drawings. 

Brief Description of the Drawings 

In the Drawings: 

10 Fig. 1 is an exploded isometric and somewhat 

diagrammatic view of a compact, modular disk file 
subsystem including a mounting frame, the sub- 
system being in accordance with the principles of 
the present invention. 

75 Fig. 2 is an exploded isometric and somewhat 

diagrammatic view of the subsystem of Fig. 1 
wherein a printed circuit substrate is extended and 
provides the mounting substrate for the head and 
disk assembly. 

20 Fig. 3 is a somewhat diagrammatic and ex- 

ploded view in perspective of an assembly of the 
elements comprising the head and disk assembly 
incorporating the principles of the present inven- 
tion. The elements depicted in Fig. 3 have been 

25 dispersed along broken explosion lines to facilitate 
illustration of the head and disk assembly. 

Fig. 4 is an exploded diagrammatic view in 
perspective along a single central axis of explosion 
of the structural elements comprising a, compact 

30 optical encoder subassembly incorporated within 
the head and disk assembly depicted in Fig. 3. 

Fig. 5 is a diagrammatic top plan view of the 
head and disk assembly depicted in Fig. 3, show- 
ing the elements thereof in place, except for the 

35 upper magnet and flux return plate, and certain 
flexible connection substrates which have been 
omitted to facilitate clarity of explanation and un- 
derstanding. 

Fig. 6 is a longitudinal view in side elevation 

40 and section of the assembly of Fig. 3 through the 
axis of rotation of the spindle motor. The section is 
along the line 6-6 in Fig. 5. 

Fig. 7 is a diagrammatic bottom plan view of 
the head and disk assembly depicted in Fig. 3. 

45 Figs. 8A, and 8B are respectively an electronic 

schematic circuit diagram of the three phase, 
brushtess spindle motor depicted in Fig. 3 and an 
electronic schematic circuit diagram of a driver 
circuit needed to operate and commutate the 

so brushless DC spindle motor; and, a bottom or 
inside plan view of one preferred layout of a small 
circuit module for carrying the circuitry depicted in 
Rg. 8A. 

Fig. 9 is an enlarged top plan view of a rotary 
55 actuator element of the the head and disk assem- 
bly depicted in Rg. 3. 
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Fig. 10 is a diagrammatic view in side elevation 
and section of a portion of the rotary actuator 
motor, taken along the line 10-10 in Fig. 4. 

Rg. 11 is an electrical block diagram of the 
control electronics for the disk file subsystem de- 
picted in Rg. 1 . 

Rgs. 12a through 12i are nine sheets of draw- 
ing which together set forth a single electrical cir- 
cuit schematic diagram of the electronics for the 
disk file subsystem depicted in Rg. 1. Rg. 12 is a 
layout plan for the nine sheets of Rgs. 12a through 
12i, and explains how these sheets should be ar- 
ranged together in order to provide the overall 
single electrical schematic. 

Rgs. 13A, 13B and 13C are respectively an 
electrical circuit schematic, a block diagram of a 
two channel monolithic read/write and head select 
circuit and a thin film flexible circuit substrate 
mounted within the head and disk assembly shown 
in Rg. 3, and which plugs into the read and write 
circuitry depicted in Rg. 12A. 

Rg. 14 is a detailed block diagram of the 
structure of a data sequencer included within the 
circuitry shown in Rg. 11. 

Rg. 15 is a detailed block diagram of the 
structure of a memory controller included within the 
circuitry shown in Rg. 1 1 . 

Rg. 16 is a detailed block diagram of the 
structure of an input/output channel interface in- 
cluded within the circuitry shown in Rg. 1 1 . 

Rg. 17 is a detailed schematic and block dia- 
gram of the structure of an analog/digital servo 
circuit included within the circuitry shown in Rg. 3. 

Rg. 18 is a detailed schematic diagram of an 
optical encoder circuit carried on the flexible circuit 
substrate depicted in Rg. 4. 

Rg. 19 is a detailed schematic and block dia- 
gram of a data separator element included within 
the circuitry shown in Rg. 11. 

Rg. 20 is a diagram of track formatting fol- 
lowed in tine disk file subsystem depicted in Rg. 1 . 

Detailed Description of a Preferred Embodiment 

As seen in Rgs. 1 and 2 a miniaturized rotating 
fixed disk data storage subsystem 5 includes in 
Rg. 1 a printed circuit card 6 carrying substantially 
all of the highly modularized and integrated elec- 
tronic circuits required to operate the subsystem 5, 
and an elongated frame 7 (shown in Rg. 1). The 
printed circuit card may be strengthened and elon- 
gated and be used as a supporting substrate 6A in 
lieu of the frame 7, as shown in Rg. 2. A mounting 
flange 8 formed as a part of the frame 7 (Rg. 1), or 
attached to the circuit card 6a by screws (Rg. 2), 
enables the subsystem 5 to be mounted in and 



occupy a single accessory slot of a single user 
computer, such as the IBM Personal Computer tm , 
for example, and thereby achieve a direct plug-in 
electrical attachment thereto. 

5 

Head and Disk Assembly 10 

A thin and compact head and disk assembly 
10, depicted in detail in Rgs. 3-10 and discussed 

10 hereinafter, is attached to 'the frame 7 (Rg. 1 ) or to 
the printed circuit board 6 (Rg. 2) via mounting 
hardware 9 which provides for some insulation of 
the assembly 10 from physical shocks to the host 
in Rg. 3, the assembly 10 is shown as includ- 

75 ing a housing 12, which functions to enclose, align, 
and/or support all of the other elements included as 
part of the assembly 10. The housing 12 is prefer- 
ably formed as a metal casting, such as of alu- 
minum. The housing 12 may also be formed from 

20 stock by machining, and may also be formed by 
sintering of formed powdered metal, in accordance 
with known technology. A continuous outer periph- 
eral wall 11 and recesses 13 (Rg. 7) serve to 
reinforce the housing 12 and also to minimize the 

25 amount of material required in its fabrication. 

A cover 14 attaches to the housing 12 via 
screws 15 and thereby encloses the interior there- 
of. A gasket 16 seals the interior of the housing 12 
from the ambient, and prevents intrusion of foreign 

30 particulate material, such as dust, which would 
interfere with the operation of the assembly 10. A 
breather filter 17 enables the pressure inside the 
housing 12 to equalize to exterior ambient Two 
ports 18 are provided through the cover 14 to 

35 enable the interior to be purged of dust particles 
during the manufacturing operation. Seals 19 seal 
the two ports 18 after purging. 

A micropore air filter 20 is mounted in one 
comer 21 of the housing 12 and filters internal air 

40 to remove any particulate contamination during op- 
eration. 

The head and disk assembly 10 includes three 
major elements or subsystems: an optical encoder 
subassembly 100 described in connection with Rg. 
45 4; a disk, spindle and direct drive spindle motor 
subassembly 200 described in connection with 
Rgs 3 and 6-8, and a rotary actuator and motor 
subassembly 300, described in connection with 
Rgs 3, 5, 6, 8, and 9. 

50 

Optical Encoder Subassembly 100 

The encoder subassembly 100 includes three 
major parts. The first part is a moving scale 112 
55 having alternating light translucent and opaque ra- 
dial microlines 113. The scale 112 is mounted on a 
ledge 302 of a substantially planar rotary actuator 
frame 304 of limited angular displacement which is 
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rotatably journalled to the housing 12 as shown in 
Figs. 3 and 5, and discussed hereinafter in greater 
detail. Thus, in this preferred embodiment the scale 
112 is also of limited angular displacement, limited 
to a maximum of approximately thirty degrees of 
arc (30°). 

The second part of the encoder 100 is a unit- 
ized encoder structure 114 comprising a light 
source holder 116 carrying an LED light source 
118 and a mirror 120, a photocell array carrier 122 
carrying and aligning a photocell array 124 and an 
overlying mask or reticle 126, a support bolt 128 
having a widened circular head or table top 130 for 
mounting the light source holder 116 and the 
photocell array carrier 122 and having a threaded 
cylindrical shank 132. A wave spring washer 134 is 
interposed between the shank 132 and an annular 
machined piateau 136 surrounding a cylindrical 
opening formed through the housing 12. The cylin- 
drical opening is sized to receive the shank there- 
through in a freely rotating relationship. A locking 
nut 140 threads onto the shank 132 after it is 
passed through the base 138 so as to secure the 
bolt 128 and the other elements it carries to the 
base 138. The photocell array 124 includes an 
upper photocell 124A, a lower photocell 124B, and 
an AGC cell 124C located between the two 
photocells 124A and 124B. 

The LED light source holder 116 is secured to 
the support bolt 128 by screws 172 which pass 
through the holder 116, and also, through the 
photocell array carrier 122 and into threaded open- 
ings 194 provided in the table top 130 of the 
support bolt 128, as shown in Fig. 4. 

The photocell array carrier 122 includes a cen- 
tral well 123 in which the photocell array 124 is 
mounted. A small printed circuit board 186 is pro- 
vided adjacent to a connection edge of the 
photocell array 124. Fine wires are then bonded 
between connection pads of the array 124 and 
corresponding traces of the circuit board 186. The 
reticle 126 is then directly mounted over the 
photocell array 124 in precise optical alignment, so 
that openings in the reticle 126, in cooperation with 
the radial microlines 113 of the scale 112, enable 
generation of polyphase incremental position elec- 
trical signals which are related to the position of the 
actuator frame 304 relative to the housing 12. 

The threaded shank 132 of the bolt 128 passes 
through the housing at the location shown in Figs. 
3 and 7. The bolt 128 includes a slot 174 (Fig. 7) 
which enables the encoder assembly 114 to be 
rotated during final assembly and optical alignment 
in the housing 12. The nut 140 enables the assem- 
bly 114 to be locked at a precise height relative to 
the scale, by virtue of compression of the wave 
spring washer 134. The nut 140 includes two trans- 
verse grooves 176 at its threads. These grooves 



176 enable the nut 140 to be glued effectively to 
the bolt 128 and to the housing 12 once proper 
alignment of the encoder and scale is achieved 
during the manufacturing process. 

s The third part of the subassembly 10 is an 

electronic circuit 142 which is preferably formed of 
electronic components secured to a flexible film 
printed circuit substrate 144. The substrate 144 is 
adapted to be placed inside the housing 12 adja- 

io cent to the encoder subassembly 100, in a well 
generally designated by the reference numeral 154 
in Fig. 5. 

The substrate 144 includes three integral flexi- 
ble connection extensions, a first extension 146 

75 enabling connection to the photodetector array 124 
via the small circuit board by screws 156 at the 
locations indicated by the broken lead lines in Fig. 
4. A second extension 148 extends to and enables 
connection of the circuit 142 to the LED light 

20 source 118, and a third extension 150 includes a 
suitable plug 152 for enabling direct overall elec- 
trical connection of the subassembly 110 to the 
disk drive control electronics circuit card 6, 6a, with 
which the head and disk assembly 10 may be 

25 used. This connection via the plug 152 is external 
to the housing 12, and the thin film extension 150 
passes between the housing 12 and the gasket 16 
to the external connection location, with the elec- 
trical traces being adjacent to the insulating gasket 

30 16 and with the mylar substrate being against the 
lip of the housing 12. 

Optical Encoder Circuit 142 

35 As depicted schematically in Fig. 18, an in- 

tegrated circuit Ul contains four operational amplifi- 
ers UIA, UIB, UIC and UID. The amplifier UIA is a 
current to voltage converter and has an inverting 
input connected to the anode of the upper 

40 photocell 124A of the photodetector array 124, and 
the amplifier UIB is a current to voltage converter 
having an inverting input connected to the anode of 
the lower photocell 124B of the array. A negative 
feedback circuit comprising a capacitor C4 and a 

45 resistor RI2 adjusts the frequency response and 
gain of the converter UIA, and a similar but adjust- 
able network of capacitor C3 and series resistors 
R9 and RIO adjusts the frequency response and 
gain of the converter UIB. The resistor RIO is vari- 

so able, so that the gain characteristics of UIB may be 
made the same as those for the converter UIA. 

A reference voltage Vref is derived from a 1 2V 
supply bus from the host computer through a net- 
work comprising a series resistor R3 and 5.0 volt 

55 zener diode CRI. The zener regulated 5.0 volts is 
applied to the non-invertinq input of an operational 
amplifier UIC. A resistance network of resistors R2 
and Rl provide at a common node a feedback path 
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to an inverting input of the amplifier UIC and a 
reference voltage Vref which connects to the com- 
mon cathode substrate of the photodetector array 
124 via a connector J2-2. The values of the resis- 
tors Rl and R2 establish the voltage present at the 
output of the amplifier UIC. This output voltage s 
supplied to two adjustable networks: the first net- 
work comprising the resistors RI6, RI7 and RI8 for 
controlling the operation of the converter UIA, and 
the second network comprising the resistors RI3, 
RI4 and RI5 for controlling the operation of the 
converter 1MB. Resistors RI8 and RI5 are individ- 
ually adjustable so that the electrical characteristics 
of the photocells 124A and 124B respectively may 
be individually controlled and equalized in terms of 
voltage output over the range of light to dark. 
These two adjustments RI8 and RI5 also enable 
each photocell 112, 114 of the polyphase encoder 
100 to be trimmed to accomodate the particular 
gap between the scale 112 and the mask 126 
without loss of current amplitude between the maxi- 
ma of light and dark conditions at each photocell. 

An automatic gain control (AGC) cell 124C of 
the array 124 is connected to an inverting input of 
an operational amplifier UID via a connector J2-31 . 
The non-inverting input of the amplifier UID is con- 
nected to the Vref node. The output of the amplifier 
UID is connected to a driver transistor QI which in 
turn supplies current from a 5 volt bus of the host 
equipment to the anode of the LED light source 
118. The cathode of the light source is connected 
through two current limiting resistors R4 and R5 to 
ground. A series network of resistors R6 and R7, in 
combination with the current put out by the AGC 
photocell 1 24C controls the current put out by the 
operational amplifier UID and actually applied to 
the LED through the driver transistor QI. R6 is 
adjustable to control quiescent current through the 
LED 118. 

Disk and Spindle Motor Subassembly 200 

The disk and spindle motor subassembly 200 
includes a very thin and flat direct drive, brushless 
spindle motor 202 which mounts in a well 204 of 
the housing 12 by three screws 205. The screws 

205 pass through openings in a peripheral flange 

206 of the motor 202 which mates with a machined 
annular surface 208 adjacent to the open well 204. 
The lower surface of the flange 206 and the facing 
surface 208 of the housing 12 are machined, so 
that the motor 202 is thereby sealed in an airtight 
arrangement with the housing 12. 

The motor 202 includes a rotating hub 210 
which has a lower flange 212. A data storage disk 
214 mounts over the hub 210 and against the 
flange 212. The flange 212 has a height adapted to 
align the data disk 214 properly within the interior 



of the housing 12. The disk 214 is coated on both 
major surfaces with a magnetic storage material 
such as a ferrous oxide or plating and provides the 
storage medium of the compact head and disk 

s assembly 10. In the preferred embodiment, the 
disk has a diameter of approximately 95 millime- 
ters, and has the capability of easily storing in 
excess of ten million bytes of formatted data. 

An airflow generator disk 216, preferably 

io formed of a low-mass plastic material, attaches to 
the top of the hub 210 by a single axial locking 
screw 218. Alternatively, storage capacity may be 
doubled by replacing the airflow generator disk 216 
with a second magnetic media data storage disk 

75 21 5 and by adding additional data transducers and 
support arms to the rotary actuator assembly 300. 
A second data storage disk 215 is shown dia- 
grammaticaJly in Fig. 11. Two opposed peripheral 
openings 220 through the disk 216 align with two 

20 openings 222 on the top of the hub 210. A spanner 
wrench is used to prevent the hub 210 from rotat- 
ing while the screw 218 is tightened. The spanner 
wrench is provided with two pins aligned with the 
openings 220 and 222. The pins pass through the 

25 openings 220 and 222 and thereby align the top 
disk 216 and the hub 210 as the screw is locked 
into place. A spacer 213 between the top disk 216 
and the data disk 214 locks the data disk 214 
against the lower flange 212. 

30 The top surface of the spindle motor 202 in- 

cludes a recessed and shielded region 224, in 
which an electromagnetic shield is placed, in order 
to prevent contamination of data stored on the 
lower surface by the electromagnetic fields gen- 

35 erated inside of the motor 202. 

As seen in Fig. 5, an aerodynamically released 
shipping latch 230 is rotatably mounted on a verti- 
cal post 232 (Fig. 3) in the housing 12. A vane 234 
and flag 236 of the latch 230 are deflected by 

40 airflow generated by clockwise rotation of the disks 
214 and 216. The airflow is sufficient to overcome 
the force exerted by a bias spring (not shown) 
which urges the latch 230 in a clockwise direction. 
A notch 238 provided in a counterweight 306 of the 

45 rotary actuator 300 is engaged by a finger 240 
when there is no rotation of the disks 214 and 216 
(and no airflow). This arrangement latches the ro- 
tary actuator 300 into a landing zone position. 

When power is removed from the head and 

so disk assembly, the counter electromotive force 
generated by rotation of the spindle motor 202 in 
response to the inertia stored in the motor 202, 
spindle 210 and disks 214, 216, is automatically 
applied to the rotary actuator 300 in order to return 

55 the actuator to the landing zone position before 
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disk rotation ceases and the aerodynamic latch 230 
is no longer deflected by airflow. This electronic 
return spring feature is described hereinafter, in 
connection with the electrical circuit elements. 

One important requirement for the head and 
disk assembly 10 is that the spindle 210 be effec- 
tively grounded to the frame. Ordinarily, an elec- 
trical brush makes contact between the spindle 
shaft and the housing externa! to the motor. How- 
ever, such arrangement adds significantly to the 
height of the motor and to the overall thickness of 
the head and disk assembly. Thus, it has been 
discovered that a grounding mechanism 250 (Fig. 
6) may be placed entirely within the spindle shaft 
252 of the motor 202. 

The preferred mechanism includes a spring 
loaded bait or tip 254 inside the hollow spindle 
shaft 252. The tip 254 is of conductive material, 
such as a carbon impregnated plastic resin ma- 
terial, and it makes direct contact with a pad 256 of 
highly conductive hardened material such as stain- 
less steel which is fixed and connected to the 
stationary enclosure 258 of the motor 202. The 
enclosure 258 is grounded to the housing 12 at the 
peripheral flange 206 by the screws 205. 

One important aspect of the present invention 
is that the electronic circuitry required to drive the 
multiple windings of the spindle motor 202 be 
sinked directly to the housing. The arrangement 
shown in Fig. 7 makes direct heat sinking of the 
driving circuitry to the housing 12 possible. In Fig. 
7, a small printed circuit module 260 plugs into a 
cable 262 from the motor 202 and also plugs into 
the circuit board 6 externally of the head and disk 
assembly 10 via a cable 264 disposed in a channel 
266 formed in the back of the housing 12. 

An integrated circuit motor driver 268 such as 
type HA13426 supplied by HTACHI America. Ltd.. 
Chicago. Illinois 60006 having its pins connected to 
the circuit board 260 as shown in Rgs. 7 and 8A, 
includes a flange 270 which is directly mounted to 
the back of the housing 1 2 in a well 272 formed in 
the housing with a sufficient depth from the lower 
surface profile in order to hold the circuit board 260 
and its components (Fig. 8B) most of which are 
located on the underside of the board 260. Screws 
273 secure the heat sink flange 270 of the in- 
tegrated circuit directly to the housing 12 inside the 
well 272. 

The circuitry for the three phase motor 202 is 
depicted in Fig. 8A, which indicates that the motor 
is Y wound and generates three phase commuta- 
tion signals by three Hall effect generators U, V, W 
responsive to a small permanent magnet disposed 
in the rotating permanent magnet in the armature 
of the motor, as is conventionally known and un- 
derstood. A fourth Hall effect transducer I gen- 



erates and puts out a once per revolution index 
signal which is ultimately supplied to the control 
electronics external to the head and disk assembly 
10. 

5 A bottom or inside plan view of the modular 

circuit board 260 (Fig. 8B) indicates one acceptable 
form of layout for the discrete components on the 
circuit board 260, in which all but two of the dis- 
crete components are mounted between the print- 

io ed circuit board and the facing bottom wall of the 
housing 12. This arrangement protects these com- 
ponents from physical harm, and it enables ready 
attachment of test equipment should troubleshoot- 
ing of the circuit carried on the module 260 ever be 

75 required. Also, the cables plug into the circuit mod- 
ule 260, enabling it to be removed and replaced 
very easily, without disturbing any other circuitry, 
and without any need to enter the dust-free hous- 
ing 12. 

20 

Rotary Actuator Subassembly 300 

The third major subassembly of the head and 
disk assembly is a very flat and thin rotary actuator 

25 subassembly 300, depicted in various levels of 
detail in Rgs. 3, 5, 6, 7 9 and 10. As already 
mentioned, the actuator 300 includes a planar 
frame 304, preferably formed of cast or stamped 
aluminum. The frame 304 includes four regions. 

30 The region 302 for supporting the scale 112 of the 
optical encoder 100 has already been discussed. 

A second region of the frame 304 is for align- 
ing and supporting a triangular electromagnetic coil 
307 of a single winding 308 whose two ends are 

as connectable at connection pins 310. The coil 307 is 
wound on a bobbin and is then integrally molded to 
the frame 304 with a suitable molding compound 
311. Regions 312 denote holes passing through the 
frame 304 which are filled with potting material 

40 during the molding process, so that the coil 307 
may be precisely aligned both radially and in the 
planar dimension relative to the frame 304. 

A third region of the frame 304 provides a 
support extension 314 for two arms 316, 318 sup- 

45 porting respectively two oppositely facing "flying 
head" data transducers 320, 322 which are dis- 
posed in proximity to the two major, data storage 
surfaces of the data disk 214, as shown in Rg. 6. 
During rotation of the disk 214, the transducers 

so 320, 322 ride or -fly" upon an air bearing in very 
close proximity to the data surface in accordance 
with what is known as "Winchester" technology. 
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The fourth region of the frame 304, aJready 
mentioned, supports the counterweight 306, whose 
mass is selected to counterbalance the other re- 
gions of the frame 304, and also to cooperate with 
the aerodynamically released shipping latch 230, 
also previously explained- The counterweight 306 
is attached to the frame 304 by screws 309. 

The actuator frame 304 includes a central 
opening 301 which reduces its mass and inertia, 
and which provides a convenient location for a 
single crash stop post 313 which is adapted to 
engage oppositely facing surfaces 315, 317 formed 
on the inside walls of the frame 304 which define 
the opening 301 The post 313 is press fit into a 
suitable opening 319 in the housing 12. A cylin- 
drical rubber gasket 321 slips over the post 313 
and dampens the impact of the frame 304 upon the 
post 313. The crash stop post 313, in combination 
with the arc length between the surfaces 315, 317, 
limits the displacement of the actuator 300 to a 
predetermined maximum. This limitation of dis- 
placement is essentia] to prevent the transducers 
from coming off of the data disk 214, and from 
crashing into the lower flange 212 of the spindle 
hub 210. 

A rotary actuator spindle includes a fixed shaft 
324 mounted upwardly from the housing 12. A 
washer 326, a lower bearing 328, a spacer 330, a 
wave spring washer 332, an upper bearing 334 and 
a locking washer 336 and screw 338 all cooperate 
to provide a freely rotating journal for the actuator 
frame 304. These elements are mounted and con- 
tained in an axial cylindrical opening 340 provided 
through the frame 304 and enable the frame 304 to 
move across an arc of approximately thirty degrees 
and thereby move the transducers radially across 
the data surfaces of the data disk 214 so that each 
of the multiplicity of concentric data tracks formed 
on each data surface of the disk 214 may thereby 
be accessed by operation of the rotary actuator 
300. 

A lower flux-return magnet plate 350 carrying a 
lower permanent magnet 352 is mounted to the 
housing 12 by screws 353; and, an upper flux- 
retum magnet plate 354 carrying an upper perma- 
nent magnet 356 is mounted to the housing 12 by 
screws 357. As seen in Fig. 10, the coil 307 is 
disposed between the two oppositely facing perma- 
nent magnets 352 and 356. 

Each magnet 352, 354 is magnetized to have 
two regions of pole reversal. The magnetic poles 
are at the major surfaces of the magnets 352, 354, 
and are complementary with each other so that a 
very strong flux region exists in the gap between 
the two opposed faces of the two magnets 352 and 
356. A polar reversal region 358 generally bisects 
each magnet 352, 354. This is so that the effect of 
the flux on e.g. the left side (Rg. 10) on the coil 



307 with current passing through it adds to the 
effect of the flux on e.g. the right side, since 
current will be passing through the single winding 

308 in one direction only. 

5 

Head Select and Amplifier Circuitry 

A thin, highly flexible mylar circuit connection 
film 360 is provided for direct connection to the 

10 data transducers 320, 322. This elongated, highly 
flexible and durable connector film 360 extends 
from a larger flexible mylar printed circuit 362 
which is preferably mounted on the upper flux 
return plate 354 and which carries some of the 

75 read and write drive circuitry and head select cir- 
cuitry required for operating the transducers 320, 
322. The plan view of the circuit 362 is depicted as 
Rg. 13C. A connection extension 364 for the mylar 
circuit 362 extends outwardly from the drive be- 

20 tween the gasket 16 and the upper face of the 
peripheral wall II along the same lineal edge thereof 
as passes the connection portion 150 for the op- 
tical encoder subassembly 100. The electrical cir- 
cuit diagram of circuit elements and connections 

25 for the circuit carried by the film is depicted Rg. 
13A. Therein, a monolithic integrated circuit 366 
provides a six channel (six head transducer) head 
select and amplification function (Rg. 13B). Only 
two head select channels, H4 and H5, are active ir> 

30 selecting between the heads 320, 322 of the sub- 
system 5 (see Rg. 13a); if an additional data stor- 
age disk 215 is used, then four channels are active 
in the head select operation. This circuit 366, is 
preferably a type SSI 117, made by Silicon Sys- 

35 terns Incorporated, or equivalent. 

Circuit Card 6 

Four flexible circuit substrates extend from the 
40 head and disk assembly 10. These substrates may 
be conductive traces formed upon thin, flexible 
mylar film, or they may be thin and flat wire cables. 
In any event, one leads to. a jack 349 for connect- 
ing internal head read/write electronics with an ex- 
45 temal read/write channel, another leads to the jack 
152 for connecting the optical encoder subassem- 
bly 100 with an external analog/digital servo ele- 
ment, another leads to a jack 353 for connecting 
the spindle motor control module 260 with the 
so circuit board 6 circuitry, and a final one 355 leads 
from the coil 307 of the rotary head positioning 
actuator 300 within the head and disk assembly 10 
to external drive electronics, being part of the 
analog/digital servo element. 

55 
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The small double sided printed circuit card 6 
carries all of the electronics required for the control 
system of the present invention (except for the 
circuits within the head and disk assembly which 
have already been mentioned). 

The circuit card 6 includes a conventional edge 
connector region 365 having properly aligned con- 
nection traces 367 for engaging corresponding 
contact pins of an accessory or peripheral circuit 
card connector of the personal computer (host sys- 
tem) in which the storage subsystem 5 is installed 
and connected solely via the traces 367 on the 
edge connector region 365. 

Four plugs 369, 371 , 373 and 375 are provided 
on the circuit card for receiving respectively the 
jacks 349, 152, 353 and 355, previously described. 
These plugs enable the circuitry inside the head 
and disk assembly 10 to extend to and be con- 
nected to the circuitry carried on the circuit card 6 
and to be supplied with power from the host sys- 
tem via the edge connector 365. 

Electronics Overview 

The following major circuit elements are con- 
tained on the printed circuit card 6 generally in the 
positions indicated in Figs. 1 and 2. (These circuit 
elements are interconnected in accordance with the 
architectural overview of Fig. 1 1 and in accordance 
with the detailed connection diagram made up of 
Figs. 12a. 12b, 12c, 12d, 12e, 12f, 12g, 12h, and 
12i, as arranged and read together in accordance 
with the Fig. 12 layout plan). 

Microcomputer 381 and Program Memory 383 

A single programmed, sequential state mono- 
lithic microcomputer 381 , sometimes referred to as 
a "microprocessor", provides overall control of the 
subsystem 5. The microcomputer 381 is preferably 
a type 7810, manufactured by NEC Corporation, of 
Japan, or equivalent. The microcomputer 381 in* 
eludes a single central processing unit (CPU) and a 
single arithmetic logic unit (ALU), as well as other 
internal supporting architecture. It executes only 
one instruction at a time. 

The type 7810 is a single chip, five volt, eight 
bit microcomputer including an internal analog to 
digital converter having eight multiplex-selectable 
analog inputs. The analog to digital converter op- 
erates continuously by converting whatever voltage 
appears at a selected input into a digital value 
which may be read at any time by the microcom- 
puter 381 under program control. 

The microcomputer 381 also includes a 256 by 
eight bit RAM, multifunctional timer/event counters, 
general purpose serial and parallel interfaces and 
input/output ports, and maskable and non-maskable 



interrupt capability. The microcomputer 381 may 
also control external memory directly, and requires 
an external program memory for containing the 
instructions which it is to execute in carrying out 

5 the supervisory functions of the control system of 
the present invention. Each instruction cycle re- 
quires one microsecond, and the basic clocking 
frequency for the microcomputer 381 is 12MHz. 
The software controlled functions of the microcom- 

10 puter 381 are discussed in greater detail subse- 
quently herein. 

The microcomputer 381 utilizes a multiplexed 
bus structure, so that the same electrical lines may 
carry both address information and data informa- 

75 tion, at different times. These times alternate, so 
that in one machine cycle, a bus may be carrying 
addressing information, and at the next cycle, the 
same bus may be carrying data information, and so 
forth. 

20 The 256 byte random access memory within 

the microcomputer 381 is used as a stack and 
provides all of the general purpose registers re- 
quired for perations of the microcomputer. 

An eight kilobyte external read only program 

25 memory 383 is connected to the microcomputer 
381, and it contains the instructions which the 
microcomputer 381 will execute during operations 
of the disk file subsystem 331. These instructions 
are presented as a listing at the end of this speci- 

30 fication. 

The microcomputer 381 is the heart of the 
control system and has two overall tasks: it super- 
vises and controls radial head position via an elec- 
tromagnetic voice coil actuator 300 of the head and 

35 disk assembly 10 via servo control loops, and it 
responds to commands from the host computer 
system by initiating and monitoring transfers of 
blocks of data to and from the host and the disk 
data storage surfaces via the controller/interface. 

40 It is important to remember that throughout the 

data read/write operations and data transfer oper- 
ations the microcomputer 381 is monitoring the 
progress of such operations and it is simultaneous- 
ly controlling the track following head position ser- 

45 vo loop so that it is tightly servoing the heads 320, 
322 at the centerline of the track at which data is 
being read or being written. 

Track Positioning and Following Servos 

so 

The subsystem servo performs two functions: 
First, it must hold read/write data transducer heads 
in alignment with the centerline of each data track 
during track following operations. Second, it must 
55 be able to perform track seeking operations which 
cause the heads 320, 322 to be moved rapidly and 
accurately from a known departure track location to 
a desired destination track location. All servo oper- 
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ations are controlled and supervised by the micro- 
computer 381 which controls the current which 
passes through the coil 308 of the voice coil ac- 
tuator 300. 

An analog/digital servo circuit 385 is connected 
to the microcomputer 381, and the circuit 385 
provides circuit elements which are required to 
carry out servo control loop functions in data track 
seeking and track following operations of the head 
and disk assembly. This monolithic circuit 385 is 
explained in greater detail in conjunction with Fig. 
18 hereinafter. 

The optical encoder assembly 100, previously 
described, responds to relative light levels indica- 
tive of position of the scale 112 and converts the 
light levels into two phase signals PI and P2 which 
are in phase quadrature. These phase signals are 
converted to voltages by the current to voltage 
converters UIA and UIB of the assembly 142 and 
are then supplied to the analog to digital converter 
within the microcomputer 381 , via the analog/digital 
servo chip 385. The circuitry of the encoder is set 
forth and discussed herein in greater detail in con- 
Junction with Fig. 18. 

The analog/servo chip 385 and related circuitry 
converts digital position values to driving currents 
and applies these currents through driving circuitry 
390 to a winding 308 of the rotary actuator 300, 
symbolized in Fig. 11 by the broken line carrying 
reference numeral 300 and interconnecting a sym- 
bolic data transducer head 320, and the moving 
scale 112. The direction and magnitude of current 
passing through the coil 308 determines the direc- 
tion and velocity of the head 320 in moving among 
concentric data tracks formed on the data storage 
major surface of the data storage disk 214. The 
servo circuit 385 is described hereinafter in greater 
detail in connection with Fig. 17. 

Storage Disk 214 

The disk 214 (and 215 in a 20 megabyte 
version of the subsystem 5) includes two major 
data storage surfaces 214a and 214b coated with a 
suitable magnetic data storage material. Each data 
storage surface provides storage room for a mul- 
tiplicity of concentric data storage tracks, there 
being some 612 logical tracks available per data 
surface. Some 24 additional spare tracks are pro- 
vided at the outer periphery of the disk surface 
214a, 214b to be used in place of tracks having 
media defects so that the first tracks required by 
the host's operating system for directory purposes 
will be free of defects, and thereby be reliable in all 
cases. 



An inner landing zone region LZ is provided so 
that the ferrite slider head 320, 322 comes into 
actual contact with its underlying data surface 
214a, 214b, and subjects it to possible abrasion 

5 only in the landing zone region LZ. Each concentric 
data track nominally holds approximately 10,416 
bytes, and is divided into eighteen data sectors, 
seventeen of them being for storage of useful data 
and one of them being held in reserve in the event 

to that a media defect renders any one of the other 
seventeen unusable. Each data sector contains ap- 
proximately 568 bytes, including 512 bytes of use- 
ful data and the remainder being sector address 
headers, error correction, speed tolerance gap fil- 

75 lers, etc. 

An index marker 399, generated by motor driv- 
er circuitry 260 controlling the spindle motor 202, 
marks the location in time for a narrow, approxi- 
mately 200 microsecond, 130 byte wide, single 

20 servo sector 401 prerecorded with track centerline 
information for each data track upon one or more 
data storage surfaces 214a, 214b of the disk 214. 

The disk 214 rotates at a substantially constant 
angular velocity, and the time period for each revo- 

25 lution is nominally 16.67 milliseconds. The motor 
driver circuitry is illustrated in Fig. 8A and includes 
an integrated circuit motor driver, such as type HA 
13426, provided by Hitachi America, Ltd., 707 W. 
Aigonguin Road, Arlington Heights, Illinois 60006, 

30 or equivalent. This integrated circuit incfudes a 
flange which is directly mounted to the base cast- 
ing 12 for the head and disk assembly 10. The 
spindle motor 202 is Y wound and it generates 
three phase commutation signals by Hall effect 

35 transducers U, V and W responsive to a small 
permanent magnet in the armature of the motor 
202, which are used by the integrated circuit to 
generate the necessary phases to drive the motor 
103, as is conventionally known and understood. 

40 A fourth Hall effect transducer I generates and 

puts out a once per revolution index signal on an 
index line. The microcomputer 381 monitors the 
index line from the motor control 105 and times the 
interval between each index marker 99 to be sure 

45 that the disk 96 is rotating at proper angular ve- 
locity, and it takes the subsystem 31 out of service 
in the event that disk rotation is determined to be 
improper. 

Two radially offset, time staggered bursts are 
so provided for each concentric data track within the 
servo sector 401. The transducer 320 reads the 
first burst and its amplitude value is sampled and 
sent to and digitized by the microcomputer 381. 
The transducer 320 then reads the second burst 
55 and its amplitude value is sampled and sent to and 
digitized by the microcomputer 381 . Differences in 
the digitized amplitude values are used by the 
microcomputer 381 to calculate centerline offset 
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correction values which are stored and combined 
with a digitized phase value and sent to the coil 
308 in order to maintain the head 320 in centerline 
alignment with each track during track following 
operations. 

The -61 2 tracks are divided into five contiguous 
zones, there being four zones of 128 tracks each 
and one zone of 100 tracks each. Track centerline 
data is acquired and stored for the tracks of each 
zone, and this data is used for initial correction 
whenever the actuator has placed the head 320, 
322 at a track within the zone. A zone timer is set 
for each zone, and times out after a predetermined 
interval, requiring that new centerline information 
for the zone be obtained before read/write oper- 
ations will be permitted. These architectural fea- 
tures and operations of the fine servo loop and 
track zones are explained in further detail in the 
referenced U.S. Patents Nos. 4,396,959, 4,419,701 
and 4,516,177, the disclosures of which are hereby 
incorporated by reference into the specification at 
this location. 

Electronic Return Spring 400 

The aerodynamically released spring biased 
shipping latch 230, already described structurally 
above, is deflected by airflow generated by rotation 
of the disk 214. This latch 230 includes a member 
which engages the rotary actuator 300, thereby 
locking the heads 320, 322 at landing zone posi- 
tions over the landing zone LZ whenever disk rota- 
tion is insufficient to generate an air bearing effect 
upon which the heads "fly" (in accordance with 
well-known Winchester technology). 

In order to be sure that the actuator 300 re- 
turns the heads 320, 322 to the landing zone LZ, 
an electronic return spring, symbolized by the 
switch 400 in Fig. 1 1 is provided in the subsystem 
5. When power is lost or intentionally removed 
from the subsystem 5, this fact is sensed, and the 
operation of the spindle motor 202 is reversed: i.e. 
it becomes a generator, and the electrical energy it 
generates, due to the kinetic energy stored in the 
rotating disk 214, is switched to the coil 308 of the 
rotary actuator 300. So long as there is disk rota- 
tion, the electrical energy generated thereby is 
sufficient to return the head to the inner landing 
zone LZ of the disk 214 and keep it there so that 
the spring-biased latch 230 reengages the actuator 
300 and thereby retains the heads 320, 322 at their 
inner landing zones LZ. The dynamics of the latch 
230 and the electronic spring return 400 are de- 
signed so that the heads 320, 322 are returned to 
the landing zones LZ in good time before the latch 
230 reengages. 



Further details of the aerodynamic shipping 
latch 98 are set forth in the referenced co-pending 
U.S. Patent Application Serial No. 06/728,674, filed 
on April 29, 1985, for Aerodynamic Latch for Disk 
5 File Actuator, the disclosure of which is incor- 
porated into this specification at the present loca- 
tion. 

A significant feature provided by the combina- 
tion of the aerodynamic latch 230 and the elec- 

70 tronic return spring 400 is that the bias force ap- 
plied to the actuator by a conventional mechanical 
return spring (and which must be continuously 
overcome during disk file operation) is eliminated 
completely. This means that the actuator 300 op- 

75 erates with significantly less power consumption, a 
consideration to be made when drawing ail of the 
power for the subsystem 5 from the accessory 
socket of the personal computer host system. 

20 Read/Write Channel 

The overall read/write channel includes a head 
select and preamp circuit 366 which is carried on 
the flexible circuit substrate 362 within the head 

25 and disk assembly 10 and which is described 
herein in connection with Figs. 13A, 13B, and 13C. 
The channel also includes read/write electronics 
409 schematically illustrated in Fig. 12A, and a 
data separator 411. The data separator 411 en- 

30 codes and decodes the data bits to and from an 
encoding format, such as 2,7 code, which is used 
in the actual record and playback process on the 
disk 214. The data separator 411 is described 
further in connection with Fig. 19. 

35 

Controller/Interface 

The controller/interface of the control electron- 
ics for the disk file subsystem 5 includes a prog- 

40 rammable data sequencer 413 having its own data 
sequencer random access memory 415, a memory 
controller 417, an input/output data random access 
memory 421 addressed by the memory controller 
417 and temporarily storing data from the data 

4s sequencer 413 from an input/output channel inter- 
face 419. 

A BIOS (basic input/output system) read only 
memory 423 is associated with the input/output 
channel interface 419, and it contains basic input 

so output program routines which are accessed and 
executed directly by the host CPU whenever its 
operating system wishes to make use of the syb- 
system 5. Actually, the BIOS memory 423 is not 
required for operation of the subsystem 5, and its 

55 inclusion is a matter of convenience for the user, 
thereby enabling the subsystem 5 to be plugged 
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directly into a personal computer host system with- 
out requiring the user to add any software driver 
routines to the operating system which are needed 
in order to use the subsystem 5. 

The BIOS memory 423 may also include a s 
collection of error and status condition routines 
which are used by the operating system of the host 
system to determine and indicate to the user the 
status and/or error condition of the disk file sub- 
system 5 from time to time. An eight bit tri-state ro 
bus driver 425 is interposed in a data bus between 
the BIOS ROM 423 and the input/output channel 
interface 419 and edge connector 365 so that the 
BIOS program routines from the ROM 423 may be 
transferred va the host bus to the host CPU and rs 
executed whenever the operating system address- 
es the BIOS memory 423. 

System Buses 



A control bus 431 extends thr&ughout the print- 
ed circuit card 6. This bus, shown symbolically in 
Fig. 11 as a single line, is actually many different 
lines. Not all lines extend to all elements. For 
purposes of convention, unless a bus line is a data 
bus or an address bus, it is considered to be a 
control bus line. Thus, the data and address buses 
shown symbolically in Fig. 11 for ease of under- 
standing and in more detail in Figs. 12A, 12B, 12C, 
and 12D, define by omission each of the fines 
making up the overall control bus. 

An eight bit undirected data bus 433 enables 
the microcomputer 381 to send digital actuator 
control values to the analog servo chip 385. Digital 
data passes over the bus 433 from the microcom- 
puter 381 to the analog servo 385 wherein it is 
converted to analog values and sent to control the 
position of the rotary actuator 300 during track 
seeking and following operations. 

An eight bit time multiplexed data and address 
bus 435 interconnects the microcomputer 381 , the 
program memory 383, the data sequencer 413 and 
the memory controller 417. 

A six high order bit (A8-A13) address bus 437 
interconnects the microcomputer 381 and the pro- 
gram memory 383. The low order eight address 
bits (AO-A7) for the program memory 383 are sent 
by the microcomputer 81 over the data/address 
bus 435 during address time to the memory con- 
troller 417 where they are latched and held in order 
to be sent over an address bus 439 to address the 
program memory 385. 

A five bit address bus 441 and an eight bit data 
bus 443 interconnect the data sequencer 413 and 
its dedicated small random access memory 415, 
which stores at most only 32 bytes. 



The input/output random access memory 421 
is addressed via an eleven bit address bus 445 
from the memory controller 417, while an eight bit 
data bus 447 connects the data sequencer 413 and 
the input/output channel interface 419 with the buff- 
er memory 421. The buffer memory 421 provides 
temporary input/output data storage and functions 
as a sector buffer, holding a maximum of two 
sectors of data which are in the process of being 
stored or retrieved from a data surface 214a or 
214b of the disk 214, in addition to all status and 
control information which passes between the host 
and the subsystem 5. 

A thirteen bit address bus 449 extends be- 
tween the edge connector 365, the BIOS ROM 423 
and the input/output channel interface 419; and, an 
eight bit data bus connects the BIOS ROM 423 
with the interface 419 and edge connector 365 via 
the tri state bus driver 425. 

Data Sequencer 413 

The data sequencer 413 is a monolithic large 
scale integrated circuit containing seven internal 
25 functional blocks, as shown in Rg. 14. These 
blocks include a registers/control logic block 461. 
This block 461 contains 32 eight bit internal control 
registers and associated control logic. The regis- 
ters may be individually written to initialize the 
30 paramaters that control data transfer, and individ- 
ually read by the microcomputer 381 in order to 
obtain status information about sequencer com- 
mand execution. This block 461 includes disk ad- 
dress registers for storing cylinder, head and sec- 
35 tor identification data, status, etc., for the data 
block to be handled- The microcomputer 381 is- 
sues commands to the sequencer 413 by writing to 
these registers. 

An error correction code/cyclic redundancy 
40 check logic block 463 generates and checks error 
correction code (ECC) or cyclic redundancy check 
(CRO) bytes appended to the data and identifica- 
tion fields respectively of each sector. This block 
enables use of either a standard CCITT 16 polyno- 
45 mial CRC or a programmable ECC. The particular 
polynomial may be up to 64 bits long and is 
determined at initialization time by values written 
into the registers/control block 461 . 

A serial/parallel conversion block 465 enables 
so parallel data from the host to be serialized for the 
disk. This logic is implemented with high speed 
shift registers which effect the necessary format 
translation between parallel and serial data. 

A host interface block 467 connects the se- 
55 quencer to the buffer memory 421 via the data bus 
447. The DMA memory controller 417 provides the 
addresses in the buffer memory 421 to which the 
data is to be transferred via the address bus 445. 
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A disk interface block 469 provides logic to 
generate and receive control signals such as read 
gate, write gate, address mark enable, etc., and it 
also passes the serial data to and from the disk via 
the data separator 411 and the read/write circuits 5 
409 and 407. 

A microprocessor interface 471 enables the 
microcomputer 381 to read and write the internal 
control registers of the block 461 to control oper- 
ations of the sequencer 413 and to monitor its io 
status. 

An interface 473 to the external random access 
memory 415, via the address bus 441 and the data 
bus 443 provides access to 32 format parameter 
registers. These format parameter registers specify 75 
the size and content of the fields within each data 
sector on the disk. There are two registers for each 
field. One specifies the number of bytes in the 
particular field, and the other specifies the actual 
value contained in that field. 20 

A monolithic integrated circuit, product code 
OMTI PFM 5050 Programmable Data Sequencer, 
available from Scientific Microsystems, Inc., 339 N. 
Bernardo Ave., Mountain View, California 94043, is 
the presently preferred implementation of the data 25 
sequencer 413. 

The function of the data sequencer 413 is to 
monitor the serial data stream coming from the 
data separator 411 in order to locate the precise 
sector of a track at which data is to be transferred. 30 
Once a sector address coming in from the data 
surface is determined by the sequencer 413 to 
correspond with the correct sector identification, 
data read or write operations are then carried out. 

In the case of a read operation, the sequencer 35 
transfers the data from the correctly identified disk 
sector (512 bytes) to the sector buffer 421 where it 
may then be passed through the interface to the 
host In the case of a write operation, the se- 
quencer transfers 512 bytes of data from the host - 40 
(stored in the sector buffer 421) through the write 
path and into the data region of the properly iden- 
tified sector in the correct track on the selected 
disk surface 214. 

The sequencer 413 is preprogrammed to carry 45 
out these transfers on a single sector basis. The 
microcomputer 381 commands the actuator 300 to 
servo on track while waiting until the sequencer has 
completed its operation before it executes any oth- 
er commands. Once the transfer of a sector of data so 
is completed, a completion signal is sent by the 
sequencer to the microcomputer 381. The micro- 
computer 381 then checks status registers within 
the sequencer 413 to be sure that no errors have 
occurred. In the case of a data read operation, the 55 
microcomputer 381 then programs the memory 
controller 417 to transfer the 512 bytes of data 



from the buffer 421 through the interface 419 to the 
host. The microcomputer 381 then continues to 
servo on track while waiting for that transfer to be 
completed successfully. 

Memory Controller 417 

The memory controller 417 is a low power 
monolithic integrated circuit for managing the flow 
of data between the data sequencer 413 and the 
buffer memory 421. and between the buffer mem- 
ory 421 and the interface 41 9 and host computer. It 
controls the transfer of 512 byte blocks of user 
data stored on and retrieved from the selected data 
surface 214, and it also controls the transfer of 
command and status bytes to and from the micro- 
computer 381. Fundamentally, the function of the 
memory controller 417 is to generate addresses 
which are sent to the buffer memory 421 via the 
address bus 445. It also resolves service request 
contentions during multiple block data transfers be- 
tween the host and the subsystem 5, when data 
blocks are being moved through the buffer 421 . 

Three channels of the memory controller 417 
are used by the subsystem 5, and word count 
registers and address registers are provided inter- 
nally for each of the channels. The microcomputer 
381 programs the controller with the address from 
or to which data is to be transferred, the number of 
bytes to be transferred, and the direction of the 
transfer. With these parameters loaded into the 
controller 417, it then executes the transfer. 

Fig. 15 sets forth a conceptual diagram of the 
structure of the memory controller 417. Inside the 
memory controller 417 a registers and control logic 
biock 475 contains the write and read registers for 
each channel. The write registers may be individ- 
ually written in order to initialize the parameters 
that control data transfer. Read registers are avail- 
able and may be individually read by the micro- 
computer 381 in order to obtain status information 
about data block movement command execution. 

An address generator 477 generates and puts 
out addresses to the buffer memory 421 via the 
address bus 445. These addresses locate the data 
to be transferred to the disk via the data sequencer 
413 or to the microcomputer 381 or to the 
input/output interface 419. In the event of a block 
transfer the address generator 477 operates auto- 
matically to increment the address value to point to 
the next location in the buffer 421 until the entire 
block of data for the selected sector is transferred. 

A data sequencer interface 479 connects the 
registers and control logic block 475 with appro- 
priate control lines of the data sequencer 413 via 
the system control bus 431 . 
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A microprocessor interface 481 enables the 
microcomputer 381 to read status registers and to 
write the control registers in order to monitor and 
control block data transfers. The memory controller 
417 also is used to demultiplex (latch) program 
addresses for the program memory 383 from the 
address/data bus 435, and these addresses, ini- 
tiated under the control of the microcomputer 381 , 
are applied to the program memory via the inter- 
face 481 and the address bus 439. 

Finally, an input/output interface 483 enables 
the memory controller 417 to control the operations 
of the input/output channel interface 419. 

A monolithic integrated circuit, product code 
OMTI PFM 5060 Four Channel Memory Controller, 
available from Scientific Microsystems, Inc., 399 N. 
Bernardo Avenue, Mountain View, California 94043 
is the presently preferred implementation of the 
memory controller 417. 

The memory controller 417 is preprogrammed 
to control the transfer of information, i.e. both data 
blocks and command and status bytes between the 
subsystem 5 and the host system. In this regard, 
the controller 417 handles and coordinates the 
passing of data blocks and control and status bytes 
back and forth across the interface 419 with the 
host system. Once a sequence of control bytes has 
been received from the host, (typically six succes- 
sive bytes sent to one of four predetermined logical 
ports to which the subsystem is programmed to 
respond), these bytes are then transferred to the 
microcomputer 381 . 

There is no data path directly between the 
microcomputer 381 and the buffer memory 421. In 
order for the microcomputer 381 to receive com- 
mand bytes and to send out status bytes to the 
host via the buffer memory 421, it is necessary that 
such bytes pass through the data sequencer 413. 
In order to write a byte to the buffer memory 421 , 
the microcomputer 381 sets up the third channel of 
the memory controller 417 for writing to the ad- 
dress of the buffer 421 to which the byte is to be 
written. Then, the microcomputer 381 writes the 
byte to a register address within the data se- 
quencer 413, and the byte is thereupon automati- 
cally transferred to one buffer address by coordi- 
nated automatic action of the sequencer 413 and 
the controller 417. A similar, but 2-step procedure 
is followed to move a byte of data from the buffer 
421 into the internal random access memory of the 
microcomputer 381 . A prefetch is used after setting 
up the controller 417 by the microcomputer 381 to 
place the first byte into the sequencer 413. A fetch 
is then used to move the byte from the sequencer 
413 into the processor's internal random access 
memory. Fetches are then used to transfer all 
remaining bytes of the sequence. 



The memory controller 417 passes data back 
and forth with the host on a byte by byte hand- 
shake basis. Once a block of data, usually a 512 
byte sector amount, has been passed successfully, 

5 completion of the transfer is signalled to the micro- 
computer 381. 

The host computer normally handles data 
block transfers from and to the subsystem 5 on a 
direct memory access basis wherein after the six 

70 command bytes have been passed to the sub- 
system 5, the host central processing unit (CPU) 
relinquishes the data bus and data is directly trans- 
ferred into the active memory of the host under the 
control of a host memory controller. Byte-by-byte 

75 data transfers are used between the storage sub- 
system 5 and the host for command and status 
bytes on a programmed input/output basis, wherein 
such bytes pass through the accumulator register 
of the host. Such transfers may be used for data 

20 blocks but would take far more time and greatly 
impair the speed advantages normally associated 
with rigid disk data storage devices. 

Input/Output Channel Interface 419 

25 

The input/output channel interface 419 is im- 
plemented as a special purpose low power VLSI 
monolithic circuit. This circuit 419 provides all of 
the circuitry necessary for interfacing the, controller 

30 elements 413, 417, 381 and related circuitry of the 
Winchester disk subsystem 5 to the inputfoutput 
channel bus of a selected host computer, such as 
the IBM Personal Computer lm . The circuit 419 
provides a buffered data path to the host 

35 input/output channel, and it provides address de- 
coding for access to eight host inputfoutput ad- 
dress ports, address decoding for access to the 
external BIOS memory 423 via the buses 449 and 
451 , and circuitry for control of host bus interrupts 

40 and DMA transfers. 

As seen in Rg. 16, the circuit 419 includes a 
port address decode block 485 which decodes 
address lines AO-A9 from the host I/O channel in 
order to enable selection of eight input/output 

45 ports: four write ports and four read ports (of which 
only three are used). Two user accessible address 
select input pins -CNTA and -CNTB are provided 
to change the address, range of the host's 
input/output ports to enable the use of multiple 

so storage subsystems 5 in the same host personal 
computer. 

A BIOS memory address decode block 487 
decodes address lines A13 through A19 from the 
host I/O channel to give a ROM select signal - 
55 ROMSEL for enabling reading of the external BIOS 
memory 423. An address select input pin -RADR is 
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provided to change the address range of the BIOS 
memory 423. An input pin -ROMDIS is also pro- 
vided to disable decoding of the BIOS address 
entirely. 

A control logic block 489 contains logic cir- 
cuitry to control the host inputfoutput port register 
reads and writes, data block transfers to and from 
the host and interrupts sent to the host. This block 
includes two internal flip-flops which control wheth- 
er the host will be interrupted at the completion of 
a command, and also whether the transfer of data 
to the host . will be by direct memory access 
through a host memory controller, or not. These 
bits are set by bits DO and Dl of a control word 
written by the host into one of the write ports of the 
control logic block, and control the logic levels on 
an interrupt request line IRQ and a data memory 
request line DRQ extending to the host A data 
acknowledge signal -DACK is received into the 
control logic block 498 from the host to indicate 
receipt of a data byte and thereby signal the readi- 
ness of the host to receive another data byte. 

A 3:1 Multiplex/Driver block 491 enables one of 
three different host input/output read ports to be 
read on the host input/output channel by the host. 
These ports include an output data buffer 493 (Port 
0) which latches data on the bus 447 from the 
buffer memory 421 and puts out the data to the 
host through the block 491 and the data bus 451 
on a byte-by-byte handshake basis. The 
multiplex/driver block 491 also selects a hardware 
status register (Port 1) located in the control logic 
489 which thereupon indicates to the host the state 
of the various control signals inside of the 
input/output circuit 419, and also a drive type regis- 
ter (Port 2), also within the control logic 489, which 
enables the host computer to read the value of four 
inputs which specify the type of disk drive in use. 
Although a fourth read port (Port 3) is available, it 
is not used by the subsystem 5. An input data 
buffer 495 latches data on the bus 451 from the 
host and puts out data to the buffer memory 421 
on the bus 447 on a byte by byte handshake 
transfer basis. 

Servo Circuit 385 

A low power monolithic analog and digital in- 
tegrated circuit 385 is provided for the 
analog/digital servo circuit. Its internal architecture 
is depicted in Fig. 17. This chip 385 includes the 
circuitry required to carry out digital to analog 
conversions to provide control current to the ac- 
tuator power drivers 519, 521 for track following 
and seeking operations. The servo circuit 385 also 
performs a peak detection function upon the read 
signal immediately following the index marker 399 
when the head 320, or 322 reads the servo bursts. 



The peak detection function enables the microcom- 
puter 381 to determine track centerline information 
from the radially offset, time staggered servo 
bursts. 

5 The servo functions are carried out by sending 

an analog direct current through the rotor coil 308 
of the moving actuator assembly 300. The direction 
(polarity) of the current passing through the coil 
determines the direction, whether in or out radially 

70 on the disk, of head movement. The electromag- 
netic motion of the head actuator assembly 300 is 
controlled by the microcomputer 381 which moni- 
tors coarse position information generated by the 
optical encoder assembly 100 and by the fine 

is position information derived from the single servo 
sector 101 via the read and write channel. 

Fig. 17 diagrams the circuitry of the servo 
circuit 385 within its environment of the microcom- 
puter 381, optical encoder 100, and rotor coil 308. 

20 Beginning with the eight bit servo data bus 433 

from the microcomputer. 381 , digital data enters an 
eight bit digital to analog converter 501 . The digital 
to analog converter is a switch-capacitor design 
and uses a 10 MHz clocking signal which is sup- 

25 plied over a line 503. The analog output from the 
DAC 501 is buffered in an operational amplifier 
DAC buffer 505 and then passes through an exter- 
nal phase lead filter 507 which provides servo loop 
phase compensation in combination with an inter- 

30 nal track following servo amplifier 509. A switching 
circuit 513 operating in response to a signal from 
the microcomputer 381 via a servo off control line 
517 enables current to be removed entirely from 
the rotor coil 308 under the control of the micro- 

35 computer 381. 

Two external driver amplifiers 519 and 521 are 
used to drive current through the coil 308. A volt- 
age output of the amplifier 509 is applied directly 
to the non-inverting input of the amplifier 519 and 

40 is applied to one end of a voltage dividing network 
comprising resistors having a two to one resistance 
ratio. A common node of the network is connected 
to the non-inverting input of the amplifier 521. The 
network is also connected at its other lower resis- 

45 tance end to a six volt reference voltage, so the 
actual voltage between three and nine volts put out 
to the amplifier 519 is proportioned about the refer- 
ence voltage when it reaches the input of the 
amplifier 521. 

so * For example, when a three volt potential is 
applied to the amplifier 519, three volts appears at 
its output. At the same time a four volt potential 
appears at the input and output of the amplifier 
521 . A one volt difference is then present across a 

55 ten ohm sense resistor 523. A one volt drop across 
the 10 ohm resistor 523 creates a current flow of 
100 milliamps which passes through the rotor coil 
308 from up to down in Fig. 17, and causes it to 
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move the actuator assembly 300. When the voltage 
at the input of the amplifier 519 is e.g. nine volts, 
only eight volts appears across the amplifier 521, 
causing a 100 ma current in the opposite direction 
to flow. 

The voltage drop across the resistor 523 is 
sensed by both amplifiers 519 and 521 at inverting 
inputs thereof, and is used, in combination with the 
control voltage applied to the non-inverting inputs, 
to control the magnitude and direction of current 
passing through the coil 308. The driving amplifiers 
519, 521 supply a maximum of approximately 100 
milltamperes to the coil 308, in either direction of 
current flow. 

The two current to vottage converters 525 and 
527 in the optical encoder subassembly 100 con- 
vert the light-induced phase currents PI and P2 into 
analog voltages. Outputs from these converters 525 
and 527 (UIA and UIB in Fig. 18) enter the micro- 
computer 381 analog to digital conversion ports 
and also enter the servo circuit 385, as shown in 
both Figs. 11 and 17. Two comparators 529, 531 In 
the circuit 385 monitor the PI and P2 voltages and 
develop digital track crossing signals which are 
returned to the microcomputer via two inverting 
amplifiers 533, 535, also inside the circuit 385. By 
generating the digital track crossing signals, the 
microcomputer 381 is able to monitor coarse head 
position during track seeking operations more effi- 
ciently than if it had to convert the PI and P2 
signals to digital values first 

A voltage reference element 537 provides a 
reference voltage to appropriate nodes of the cir- 
cuit elements within the chip 385 as shown in Fig. 
10. A six volt buffer 538 provides a reference six 
vofts to each of the DAC buffer 505 and the servo 
amplifier 509. The six volt reference enables the 
DAC to be varied in its output in a range between 
three and nine volts over 256 equal increments. 

A five voft zener reference from the optical 
encoder assembly 100 passes through a buffer 
amplifier 539 and an external transistor 541 before 
being put into the reference voltage input Vref of 
the analog to digital circuit within the microcom- 
puter 381. When the zener voltage from the en- 
coder 100 drifts with temperature changes, these 
small changes are also tracked by the digital to 
analog converter of the microcomputer 381. 

The analog servo chip 385 works primarily with 
a twelve volt power supply, while the microcom- 
puter 381 works with a five volt power supply. A 
comparator circuit 543 monitors the five volt bus 
within the servo chip 385. If the five volt reference 
is lost at the chip 385, the comparator 543 shuts off 
the buffer 539, thereby preventing the microcom- 
puter 381 from becoming damaged because the 
Vref port is being forced to ground potential. It 
should be noted in this regard that all of the out- 



puts of the servo circuit 385 leading directly to the 
microcomputer 381 are open collector or are output 
protected, so that the microcomputer 381 is there- 
by protected against the failure of the chip 385 or 

5 any of its elements. 

The chip 385 also includes a detector amplifier 
545 which is directly connected to the read/write 
channel in order to receive the sector servo bursts 
prerecorded in the single servo sector 401. The 

10 peak voltage levels of the read/write channels are 
translated by the amplifier 545 into leveis more 
suitable for the analog to digital converter input 
port AD3 of the microcomputer 381 , driven by the 
output of the amplifier 545. 

75 

Data Separator 41 1 

The data separator element 411, preferably 
formed as a monolithic integrated circuit, such as 
20 type OMT1 20527 available from Scientific Micro- 
systems, Inc., 339 N. Bernardo Avenue, Mountain 
View, California 94043, or equivalent, is depicted in 
Fig. 19. The data separator 411 performs three 
functions. 

25 First, the data separator 411 determines head 

position relative to the data format This task is 
accomplished by writing a special pattern onto the 
data surface 214, commonly referred to as an 
address mark pattern, which can be identified when 

30 a read operation is initiated. The separator circuit 
41 1 generates and writes the address mark pattern 
while formatting each data track, and it identifies 
the address mark when a read operation is begun. 
Second, the data separator 41 1 defines bit cell 

35 boundaries on the disk data surface. This task is 
accomplished by a phase locked oscillator (PLO). 
The PLO constructs a data clock signal which 
precisely defines bit cell boundaries as they exist 
in the formatted data track. Essentially a flywheel 

40 oscillator with inertia to average out minute fluc- 
tuations in disk speed, the PLO constantly updates 
the phase and frequency of the data clock signal 
throughout each data read operation. 

Third, the data separator encodes and decodes 

45 non return to zero (NRZ) data to a format more 
suitable for being recorded on the media as a 
series of magnetic flux transitions, due to con- 
straints peculiar to magnetic recording phenomena. 
One suitable format is 2,7 code, and the data 

so separator 41 1 handles the code conversion. 

The monolithic data separator circuit 411 as 
shown in Fig. 19 includes a sync field qualifier 
circuit 551 . This circuit 551 inspects the frequency 
of incoming pulses from the read electronics 409. 

55 The output of the circuit 551 is a logical one or 
zero, depending upon the frequency of the incom- 
ing pulses. For example, if the pulses are sepa- 
rated by less than 204 nanoseconds or more than 
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602 nanoseconds, the output will be low. If the 
pulses are separated by greater than 300 
nanoseconds and less than 492 nanoseconds, the 
output will be high, indicative that a sync field is 
validly present in the raw data stream. Only if the 
sync field is valid will the PLO be permitted to lock 
onto incoming data. 

This circuit 551 is also used to reset a read 
sequence. A search for the address mark cannot 
be initiated until the sync field is valid for eight 
bytes of data. Only then may a read sequence 
progress if the sync field falls to zero. If it does 
before the consecutive eight bytes are received, 
the read sequence is automatically reset. This 
mechanism protects against write splices. For ex- 
ample, data having a hexadecimal value of 33 
encodes to one pulse every 800 nanoseconds, 
which will force sync field low. A field of hex 33 is 
written on either side of a five byte field in the 
format where write splices may occur. This forces 
the read sequence to be reset upon entering the 
write splice and coming out of it. This is important, 
because over time, write splices could form into 
any pattern of data including hex FF data and an 
address mark. However, by making the correct 
sequence greater than five bytes and forcing a 
reset of the read sequence on either side of the 
write splice, a false address mark cannot be gen- 
erated. 

A read control circuit 553 provides a mecha- 
nism to discover where the data transducer head 
320, 322 is located relative to the data format of a 
track being read, and to lock the PLO to the disk 
data. The control circuit 553 includes a four bit 
asynchronous counter, three state holding flip flops 
and various decoding logic. A Lock to Data (LTD) 
signal forces the PLO to phase lock to the read raw 
(RD RAW) pulses coming from the read channel 
409. A bit sync (BITSY) signal enables the decoder 
to block incoming encoded bits for correct decod- 
ing. A search for address mark (SAM) signal en- 
ables another state machine 555 to determine 
whether an address mark is present on the disk at 
the precise moment, or not. The appropriate action 
is then taken by the SAM circuit 555. 

The phase lock oscillator 557 defines the bit 
cell boundaries as they exist on the formatted disk 
during a read operation. The PLO 557 comprises a 
phase comparator, a filter and a voltage controlled 
oscillator (VCO). The phase comparator compares 
the phase of the encoded data read from the data 
surface 97 with the VCO signal. It then supplies a 
current via an I.SRC .SNK pin whose duty cycle is 
proportional to the phase difference between the 
two signals. The filter requires external passive 
components to provide phase compensation to the 
phase lock loop, to attenuate the high frequency 
components of the LSRC.SNK signal, and to con- 



vert the current into voltage. The VCO is a voltage 
to frequency converter which provides the decode 
machine with a bit rate clock of the same phase as 
raw data. The frequency is determined by the 

5 filtered LSRC.SNK signal. 

A decode machine 559 and a bit sync logic 
block 561 , taken together, are the heart of the data 
separator. They take in encoded data, such as in 
2,7 code format, or another suitable format, from 

10 the read channel 409, decode such data and put it 
out as NRZ data in phase lock with the read clock 
RD.CLK signal. There are two code bits for every 
one NRZ data bit, and the code bits must be 
blocked together correctly before they may be 

rs decoded. The bit sync logic block 561 determines 
correct blocking of encoded bits in response to a 
valid bit sync signal (BITSY) as generated by the 
read control circuit 553. 

A write address mark state machine 563 gen- 

20 erates the write address mark signal (WAM) at a 
specific time related to the address mark enable 
signal AM.ENABLE. The WAM signal is used to 
invert two adjacent code bits. This alters a correctly 
encoded byte of data into a unique pattern which is 

25 not generated by the encode logic because of the 
encoding rules of the particular code employed. 
This pattern serves as the address mark. 

An encode machine 565 converts NRZ data 
from the data sequencer 413 into encoded data in 

30 accordance with the selected encoding scheme, 
whether it be 2,7 code or some other satisfactory 
code. Encoding operations are carried out when- 
ever the write gate line (WRT.GATE) is enabled. 
When the write address mark signal WAM is as- 

35 serted, code bits are inverted. Code bits are syn- 
chronized to the reference clock signal REF. 
CLOCK provided from the data sequencer 41 3. 

A clock generation and multiplexing circuit 567 
contains the circuitry required to divide the refer- 

40 ence clock signal by two in order to generate a 
write reference clock WREFCLK signal. This signal 
is required for the encoding operation of the ma- 
chine 565. The multiplexer in the circuit 567 steers 
one of two inputs to a read reference clock output 

45 RD.REF.CLK which goes to the data sequencer 
413. During a read operation, the read clock signal 
RD .CLK (which is synchronous with the NRZ data 
put out by the bit sync logic block 561) is passed 
to the data sequencer 413 to synchronize it with 

so the NRZ data stream. 

A test logic block 569 enables special tests to 
be carried out on the data separator chip 411. Such 
tests include holding the LTD line high in order to 
measure loop parameters of the PLO 557. Also, 

55 data may be delayed from the disk with respect to 
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the bit cell in order to perform window margin 
testing. And the time lag between two internal 
signals may be changed in order to optimize the 
setup time on the phase comparing flip-flop. 

Disk Format 

A format arrangement for the subsystem 5 is 
depicted in Fig. 20. Therein, eighteen identical sec- 
tors are provided following the index mark 399 and 
the post-index gap which contains the wedge servo 
bursts and a tolerance region for index drift An ID 
preamble contains 12 bytes of hex FF data. Its 
purpose is to synchronize the PLO 557 before the 
data sequencer 413 reads the ID DATA RELD. The 
hex FF pattern is used because it provides the 
highest frequency read pulses of any single byte 
repeating pattern. Its length allows for two bytes of 
PLO sync detection before locking the PLO, five 
bytes of PLO sync time, one byte of phase set 
time and four bytes for margin. 

An ID SYNC BYTE is the single address mark 
byte for each sector. It is made unique by violating 
the encoding rules otherwise carried out by the 
encoding machine 565. The resultant unique pat- 
tern is known to, read and checked by the data 
sequencer 413 in order to validate the particular 
sector ID. 

An ID MARKER BYTE is a byte of hex FE data, 
chosen only to be different from the DATA MARK- 
ER BYTE. The data sequencer 413 uses this byte 
to determine that a sector ID data field is about to 
be read. 

An ID DATA FIELD includes four bytes holding 
the sector address in the form of cyiiner high, 
cylinder low, head and sector. 

An ID ECC field of two bytes of CRC informa- 
tion are used by the sequencer 413 to check the 
validity of the sector address. 

A three byte field ID POSTAMBLE of hex 33 
data is provided to guarantee a stable read clock 
from the PLO during the time that the last bits of 
the ID ECC field are read, decoded by the decoder 
559 and passed to the sequencer 413. 

A DATA PREAMBLE field duplicates the ID 
Preamble field, and its purpose is to synchronize 
the PLO before reading the data field. 

A DATA SYNC BYTE serves the same purpose 
for the data field as was served by the ID DATA 
SYNC BYTE for the ID data field. 

DATA MARKER BYTE is a byte of hex F8, 
used by the data sequencer 113 to determine that 
a data field is about to be read. 

DATA RELD. This field is for storing a block of 
512 bytes of user data. It is initially recorded with 
hex 33 data during a track format operation. 

DATA ECC is a six byte field for data error 
correction code. 



DATA POSTAMBLE is a three byte field of hex 
33 data and guarantees a stable read clock from 
the PLO during the time that the last bits of ECC 
are being read, decoded and passed to the se- 

5 quencer413. 

INTERSECTOR GAP is a ten byte field of hex 
33 data containing three functionally separate sec- 
tions. A three byte write-update field allows for the 
data preamble and data field to move down the 

w track by up to three bytes between a format opera- 
tion and a write update operation. This shift is 
accounted for by the data format encode and de- 
code delays, a one byte sequencer delay and a 
number of single bit ^synchronization delays. A 

75 five byte speed tolerance gap allows for a plus and 
minus point four percent (.4%) speed variation of 
the spindle motor 202 to be accomodated between 
track format operations and write update operations 
(a .8% maximum difference). Finally, a two byte 

20 pad guarantees at least two bytes of hex 33 data 
before the ID Preamble of the next sector. This 
forces the PLO sync field detector to restart the 
address mark search sequence even if it had fal- 
sely detected some PLO sync data from write 

25 splices in the speed tolerance field. 

PREINDEX GAP is a 43 byte field of hex 33 
data at nominal spindle motor speed. Its purpose is 
to allow for motor speed variations during track 
formatting. An overspeed of up to 0.4% may be 

30 accomodated. 

Control Software 

The microcomputer 381 operates essentially in 

35 an interrupt driven mode. There are several inputs 
to the microcomputer 381 for setting its internal 
interrupt request flags. All interrupts are software 
maskable, except a non-maskable interrupt line 
which may be operated by the host operating sys- 

40 tern (write to Port 1), in order to reset the sub- 
system 5 should it become lost (hung up) during 
command execution. The host reset operation is 
flagged through the BAR NMI port, pin 25. All other 
host commands are initiated by an interrupt which 

45 is flagged through bit position 3 of Port C. (BAR 
INT2, pin 20), which may be software masked if 
some task having a higher priority is in a critical 
phase of execution. 

There are three main phases of software ex- 

50 ecution: Initialization, Main Loop, and Command 
Execution. The initialization phase, at power on (or 
upon an NMI host RESET command) resets and/or 
preloads all of the control registers with initial or 
default values required for proper operation of the 

55 data sequencer 413, the memory controller 417 
and the head and disk assembly servo system. 
The operating parameter registers within the micro- 
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computer 381 are also cleared and set with initial 
or default parameters. Once the subsystem 5 is set 
up; the microcomputer 381 seeks to track zero and 
enters the main loop. 

The main loop is essentially an idle mode for 
maintaining the status quo. A track following servo 
value generated by the microcomputer 381 is 
latched into and converted to an analog voltage by 
the digital to analog converter 501 and is converted 
to a current which passes through the rotor coil 308 
to keep the heads 320, 322 centered on track. A 
phase byte selects which phase, whether PI, P2, 
BAR PI, or BAR P2, should be used for servoing 
on-track. (PI and P2, being in quadrature, logically 
define four adjacent track locations and bound- 
aries). In the main loop, the microcomputer 381 
creates a tight on-track servo loop about the se- 
lected phase signal. The selected phase is digitiz- 
ed and read, and the servo loop is updated, ap- 
proximately every 90 microseconds. The analog to 
digital conversion process requires approximately 
48 microseconds, and the digital processing and 
update requires the rest of the 90 microseconds, 
the time duration for main loop execution. This 
updating of the track following servo continues re- 
peatedly until an interrupt occurs. It is expected 
that approximately 95 percent of the useful life of 
the subsystem 31 will be spent in executing the 
main loop. 

There are three main interrupts which cause 
the microcomputer 381 to exit the main loop. The 
first interrupt is an Index Interrupt, which occurs 
once each revolution of the disk 214. The prerecor- 
ded A and B bursts in the servo wedge 401 are 
read sequentially and peak amplitude sampled 
through the analog to digital converter within the 
microcomputer 381. The two amplitude values are 
compared, and any difference value is used in a 
computation to provide an error correction value 
which is combined with the digitized selected 
phase value from the optical encoder to derive the 
correction value sent to the digital to analog con- 
verter 501 . At the completion of the servo routine at 
Index, the microcomputer 381 returns to the main 
loop. 

Another interrupt is a RESET operation from 
the host which is generated by the host's operating 
system in the event that the subsystem 5 fails to 
respond to other host commands. The Reset op- 
eration creates a hardware interrupt in the sub- 
system 5 and forces it to reinitialize. In this man- 
ner, if the microcomputer 381 gets out of sequence 
in executing commands, error recovery, if possible, 
will be accomplished. 

A third interrupt is a SELECT Interrupt which is 
generated by the host computer when it sends a 
Host Command to the subsystem 5. Each com- 
mand received by the microcomputer 381 is com- 



pared with a table of valid commands. When a 
matchup occurs, the table provides an addres for a 
command execution routine in the program mem- 
ory 383 which corresponds to the particular valid 

5 command received from the host. If no matchup 
occurs, the command is rejected as invalid. Or- 
dinarily, when a command is received, the micro- 
computer 381 is interrupted, and jumps to, and 
begins executing the command routine for the par- 

70 ticuiar command. At command completion, the 
microcomputer 381 returns to the main loop. 

A Timer Interrupt occurs every 150 micro- 
seconds during seek operations which are carried 
out in response to a select interrupt which requires 

75 a seek operation. 

There are a number of Host Commands which 
may be given to the subsystem 5. The following 
Host Commands are representative of the types of 
commands likely to be sent by a host to the 

20 subsystem 5 in order to carry out useful data 
storage and retrieval operations. 

TEST DRIVE READY which is a check to see if 
the subsystem 5 is ready to receive another com- 
mand, or to see if it is e.g. seeking or otherwise 

25 unavailable. The subsystem 5 puts out an error 
message to the host in the event that it is not 
ready. 

REQUEST SENSE STATUS which is invoked 
to send four bytes of a sense block which char- 

30 acterizes current status of the subsystem 5. This 
command requires the subsystem 5 to be set up to 
transfer the four bytes; the bytes are placed in the 
buffer 421, and then they are sent to the host via 
the interface 419. The microcomputer 381 waits 

35 until the host signals receipt as a command com- 
pletion. Any error conditions are sent to the host in 
response to this command. 

READ ERROR LENGTH. This command sends 
the host a one byte burst length of the last ECC 

40 error. It requires a setup for a one byte transfer via 
the buffer. 

INITIALIZE DRIVE CHARACTERISTICS. This 
command enables the host to initialize the char- 
acteristics of the subsystem 5. The memory con- 

45 troller 417 is set up to transfer eight bytes of data 
from the host through the buffer 421 and into the 
internal RAM of the microcomputer 381. This in- 
formation includes the maximum number of cyl- 
inders (track locations) and heads. Also, the maxi- 

so mum ECC data burst length is stored. 

FORMAT TRACK. This command enables the 
host to format a single track. The track address is 
checked to be sure it is legal; the sequencer 413 is 
set up for formatting; the format track command is 

55 sent to the sequencer; and a "bump detect" func- 
tion is monitored throughout the formatting opera- 
tion. (The Bump Detect Routine is used to detect 
whether any physical impulse has jarred the sub- 
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system 5, causing the head to move off of track 
centerline alignment. This routine calls for monitor- 
ing the selected servo phase put out by the optical 
encoder 100 as closely as possible (75 micro- 
second loop) during the format operation. If a bump 
is detected, the one track format operation is auto- 
matically repeated) 

FORMAT DRIVE. This command is invoked by 
the host in order to format all of the host-accessible 
storage capacity of the subsystem 5. It includes 
carrying out the FORMAT TRACK command for all 
of the data tracks, beginning with the track speci- 
fied in the command and continuing through track 
611. 

READ DATA. This command enables the host 
to receive the data from one or more specified 
number of sectors. A legal starting address is 
checked. Then, the actuator 300 is commanded to 
move the head transducer from its present track 
location to the target or destination track. After the 
seek, the memory controller 417 and the data 
sequencer 413 are set up for operations at the 
destination track, and a command byte is sent to 
the sequencer to start data transfer operations. The 
microcomputer 381 waits until the sequencer 413 
finishes reading the proper sector at the destination 
track. Errors are checked for, and the microcom- 
puter 381 waits until the host memory channel is 
ready to receive the data commanded. The transfer 
process to the host is then initialized in the mem- 
ory controller 417 and the transfer to the host is 
carried out. 

If there are additional sectors to be transferred 
to the host the next address is generated and 
loaded into the sequencer, and the sequencer is 
then restarted. This process goes on until all of the 
data is transferred to the host. If the operation 
requires access to sectors in adjacent tracks, auto- 
matic single track stepping (and head switching) is 
commanded at the appropriate time by the micro- 
computer 381. When all sectors have been trans- 
ferred, the command is completed and the micro- 
computer signals command completion to the host 

WRITE DATA. This command follows the same 
progression of steps as are followed for the READ 
command, with the exception that data is received 
from the host over the interface 419 and via the 
buffer memory 421. The microcomputer 381 
moves the selected head to the correct track loca- 
tion. The first block of data is transferred from the 
host to the sector buffer 421. The sequencer 413 
begins reading sector headers. When the right sec- 
tor is located, the sequencer transfers data from 
the buffer 421 through the write channel, so that it 
is recorded in proper time and position in the data 
area of the sector. This process is carried out for 
each sector, until the command is completed. Dur- 
ing the writing process, the microcomputer 381 



while waiting for a command completion signal 
constantly performs the bump detect routine, to be 
sure that writing is inhibited in the event that a 
bump is detected. If a bump is detected, the sector 
5 is rewritten after the head and disk assembly has 
stabilized. 

Other Commands. There are a number of utility 
commands (such as a SEEK which is not a part of 
a READ or WRITE command) which may be pro- 

70 vided to carry out certain tests and operations 
desired by the host. These commands are a matter 
of design choice and are routinely understood in 
the art and are not essential for successful opera- 
tion of the subsystem 5. For this reason, they are 

75 not described herein. 

Command Structure and Addressing 

Every command which is sent to the sub- 

20 system 5 by the host is six bytes long. The first 
byte is a command code to identify the type of 
command, and the succeeding bytes provide the 
necessary parameters to carry out the command- 
Then, typically a block of sector data (512 bytes) is 

25 sent to or from the subsystem depending whether 
the command was a write or a read command. 
Other commands are the Initialize Drive Character- 
istics command which transfers eight bytes of data 
from the host to the subsystem 5, the Request 

so Sense Status command which transfers four status 
bytes from the subsystem 5 to the host and the 
Read Error Length command which transfers one 
byte from the subsystem to the host. 

After the subsystem 5 has completed each 

35 command, the microcomputer 381 sends out a one 
byte command completion signal to the host of 
which only two bit positions are used. The first bit 
indicates drive number (whether drive number zero 
or one) and the other bit indicates whether or not 

40 an error was detected during command completion 
within the subsystem 5. 

All communication between the subsystem 5 
and the host system is carried out across eight 
ports: four input ports and four output ports of the 

45 host system. The ports are paired together, so that 
for example port 0 which is at a single logical 
address is one port in its input mode and in its 
output mode is another port All data transfer is via 
port 0. All hardware status information is trans- 

5b ferred from the subsystem 31 to the host system 
via port 1. The host reads the status port during 
data exchanges so that it may synchronize its 
operations with the state of the subsystem 5. For 
example, it looks at the request bit of port 1 before 

55 sending each command byte. 
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Port 1 has very different meanings in read and 
write modes, in the read mode port 1 enables the 
host to read the hardware status lines of the sub- 
system 5. The lower four status bits of port 1 are 
used to carry out a handshake control for each 
byte of data transferred between the host and the 
interface 419 of subsystem 5. The busy bit (3) is 
set by the subsystem 5 whenever it is in the 
process of executing a host command. For exam- 
ple, the busy bit is set by the subsystem 5 when 
the host selects it for an operation (a write to port 
2) and remains set until the command completion 
byte is sent to the host via port 0 at the completion 
of execution of a host command, whereupon the 
busy bit of port 1 is cleared. 

A control/data bit (2) indicates the status of the 
data bytes being transferred via port 0, whether 
control bytes or data bytes. An input/output bit (1) 
indicates whether the data at port 0 is output from 
the host or input to the host from the subsystem 5. 
(Output, if user data, corresponds to a Write com- 
mand; Input, if user data, corresponds to a Read 
Command). A request bit (0) enables a byte by 
byte transfer handshake control. The setting and 
clearing of this bit coordinates the transfer of each 
byte between the host and the interface 419, dur- 
ing non-DMA data transfer operations as when 
command bytes are being sent 

A write operation to port 1 by the host gen- 
erates a reset signal which results in a non-maska- 
ble interrupt of the microcomputer and a 
reinitialization of the subsystem 5 under host op- 
erating system control. 

Port 2 is used by the host to read a drive type 
byte which may be used to indicate to the host 
which type of peripheral is attached to the host 
system. This byte may be polled, for example, by 
the host to determine storage capacity size, in the 
event that the storage capacity of the subsystem 5 
is increased e.g. to 20 megabytes by the addition 
of another data storage disk 215, as shown in Fig. 
11. 

A write to port 2 generates a controller select 
pulse which sets a flip-flop within the Input/Output 
Interface 419 which has an output line -BUSY. This 
line interrupts the microcomputer 381 when a com- 
mand from the host has been received at the 
interface 419. To start a command sequence, the 
host writes to port 2, causing the -BUSY line to 
become true. This event is detected by the micro- 
computer 381 and it leaves the main routine and 
begins a command execution routine. At the same 
time, the host monitors the subsystem hardware 
status port 1. As soon as the host sees the busy 
signal being asserted (true), the command/data - 
(C/D) line being asserted (true), the input/output 
line not being asserted (not true), and the request 
line being asserted (true), it knows that the sub- 



system 5 is ready to receive the first command 
byte. The first byte is then written to port 0 by the 
host and is temporarily stored the input data buffer 
495 of the I/O interface 419. An ACK signal is then 
5 sent to the memory controller 417, telling it that the 
first command byte is in the buffer 495. The mem- 
ory controller 417, drops the request signal, gen- 
erates a Memory Enable signal, and the byte is 
then transferred to the buffer 421 and stored there- 

io in at an address commanded by the memory con- 
troller 417. The memory controller then raises the 
request signal again, thereby signalling the host to 
send the next command byte. This procedure is 
followed until all six command bytes are stored in 

75 the buffer 421 . They then go to the microcomputer 
381 for execution, and at the completion of execu- 
tion a command completion byte is latched into the 
output data buffer 493 read by the host at port 0. 
Port 3, the fourth port, is not used as a read 

20 port. It is used as a write port by the host to 
enable/disable DMA operations and interrupts sent 
to the host from the subsystem 5. Thus, the host 
may write to port 3 before every command so that 
it may specify to the subsystem 5 whether the host 

25 expects to be interrupted at the end of the com- 
mand, and whether the command to be executed 
will use block transfers by DMA if it is e.g. a read 
or write command. 

EXAMPLE 1. The subsystem 5 is in the main 

so loop, servoing on track. The host operating system 
will write to port 2 which will create a signal -BUSY 
which is an interrupt to the microcomputer 381 and 
which causes it to exit the main loop. The micro- 
computer 381 enters an interrupt service subrou- 

35 tine which will cause the memory controller 417 to 
raise the Request bit in order to obtain the first 
command byte via port 0. When the host writes the 
command byte to port 0, an acknowledge signal is 
sent to the memory controller 417 causing it to 

40 lower the Request signal and temporarily store the 
byte in the buffer 421. The Request bit is again 
raised, and the next byte is received across the 
interface 419 in the same manner and stored in the 
buffer 421. The handshake via the Request bit of 

45 the status port 1 continues until all six bytes of the 
host command have been received and stored in 
the buffer memory. The memory controller 417 is 
preprogrammed so as to expect to handle recep- 
tion of the six command bytes. Completion of re- 

so ception of the six command bytes is signalled to 
the microcomputer 381, whereupon it transfers the 
six bytes from the buffer 381 to its own registers 
via the data sequencer 413 as already explained 
and decodes the command by comparison with a 

55 list of valid commands in a look up table stored in 
the program memory 383. Once the command is 
decoded, the microcomputer 381 jumps to the rou- 
tine necessary to carry out that command. In the 

21 
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event that the command received does not cor- 
respond to any of the valid commands listed in the 
lookup table, an invalid command error message is 
returned to the host. At the completion of execution 
of a command, a command completion acknowl- 
edge signal is returned to the host The occurrence 
of any error known to the subsystem 5 occurring 
during command execution is also signalled to the 
host and it can then test the status of the sub- 
system in an attempt to learn what type of error 
occurred. 

EXAMPLE 2. One critical operating situation 
arises in the situation where the first host command 
received by the system is a Seek command, and 
the very next command received is a Test Drive 
Ready command. During the fastest portion of the 
seek, the microcomputer 381 has to receive, pro- 
cess and complete the command by returning a 
status byte to the host, while simultaneously moni- 
toring track to track crossings of the head and 
actuator structure, all in such a manner that the 
actuator does not become lost. In order to carry out 
this worst case operating scenario, the processing 
task for processing the incoming command from 
the host is divided up into several segments. The 
microcomputer 381 accomplishes the segments in 
the very little time available between the track 
boundary sensing and calculations which are re- 
quired to maintain control over head position during 
the seek. The microcomputer 381 in effect begins 
to process the incoming command, and goes as far 
as it can with the process until it is time to leave it 
and to sense the track crossing and increment - 
(decrement) the track counter. Then, the micro- 
computer 381 returns to the task of processing the 
incoming command until the next time interval 
elapses for monitoring track crossing. 

The seeking algorithm employed in the sub- 
system 5 is interrupt driven by a timer. It is a 
position algorithm, rather than a velocity or accel- 
eration algorithm. Every 150 microseconds during 
track seeking, the microcomputer 381 is interrupted 
and carries out a Seek routine. It looks at the digital 
PI-P2 phases to see how far the actuator has 
progressed in that fixed time interval, i.e. how 
many tracks have been passed over by the head 
during that time; and, it updates the tracks tra- 



versed register and checks actual location of the 
transducer against a look up table containing a 
power acceleration curve which contains expected 
position data. Finally, it adjusts the acceleration of 

5 the actuator 100 to bring head position into cor- 
respondence with expected head position stored in 
the look up table. 

For example, if the head 320, 322 has crossed 
20 tracks by the end of the interval, and the look 

10 up table says the head should have crossed 25 
tracks by that time, the acceleration (current 
through coil 91) is increased to catch up. If the 
actuator 100 is four tracks off of the target track 
location stored in the look up table, the actuator 

is 100 will receive a maximum torque value - 
(maximum current will be passed through the coil 
308). At the completion of the Seek command, the 
actuator 300 will be permitted to settle at the target 
track. 

20 Since the optical encoder 100 is capable of 

separately identifying each one of four tracks, the 
timer interval must be selected in relation to the 
maximum head actuator seek velocity, so that the 
head will not move more than three tracks during 

25 the time interval, If it were to move four tracks, a 
hopeless ambiguity would arise, making it impos- 
sible for the microprocessor to update the track 
count register and to calculate the current correc- 
tion value. 

30 Here follows an object code listing of a control 

program which actually carries out the operations 
described hereinabove in a subsystem constructed 
in accordance with the presently preferred sub- 
system 5 as described. In this listing, in Tektronics 

35 format each horizontal line represents a separate 
record. The slash mark is the beginning of each 
record. The first two hexadecimal bytes correspond 
to the address of the first byte of the record. The 
third byte corresponds to the hexadecimal count 

40 number of data bytes in the record. The fourth byte 
comprises an eight bit sum of four bit hexadecimal 
values for the six digits which make up the address 
and byte count. The last byte of the record is an 
eight bit check sum of the four bit hexadecimal 

45 digits comprising the program data bytes. All bytes 
between the fourth byte and the last byte of each 
record are program data bytes. 
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/ OOOOt)3 Ot3 3477b 0 1 7 
/000403075412010D 
/0008040C 101 1AA21 1A 
/00100S06549CFF010441 
/001S040D69014E622A 



/00201E11B04CE3404D13AOAA62436F70797269676874203139383S20504CS353204434 
/003E1E2065762E20436F72702E4B4434E8166419086BS07112EF68FF6407FF6406FF83 
/ 005C 1 E2004FFFFAA40940 1 54Dq004844S49FFF640 1 1 D68807 1 1 2EF6SFFA A6268FF69B 1 
/ 007 f\ 1 E20007 1 0 10 5B A6300640080640 1 5469004DD269004DD3640200697F40D46908 1 B ' 
/ 0098 1 E204DD 1 690S4DD0 1 068FF04FFFF7 1 02003402FF24O3FF6BFC3 1 7 1 6E047 1 72047E 
/OOB61E20141006701E83FF3413004SS334COFF4S9371020840E61440A7130302F76427 
/0QD41E204A0S4F7E6406FF344700703E9DFF69006364636363634843006407E7AA4063 
/OOF21E2017134093116A02013837014S22414702C64CC260CAC6ES4CC260CAE369023F 

/ 0 1 2E03 1 40B 4F A72F° SAA626 ^ 

/01311E14000104030607080AOBOCODOEOFEOE3E4E3E6E7E8E9EAEBECEDEEEFFOF1F2D3' 
/0 1 4F 1 E23F3F4F3 1 F037F0452042606D 303D2O3970S5406 A60F3B034A03BC03A303B244 
/016D1E2302AE02FB02DD03B206390AACOAD309FD09AEOSED08F40A4FOBCBOAA10B1BA4 
/OlSB 1E230AEB09D008E30873093466FF718009401 10C6409F740A701401 1O2B8700E43 
/01A91E23A2FF636603342B03346EFF3367203472FF4B00713E003436FF01693D016864 
/01C71E231A48334S33483507033D0167073F3DOA073F3B016A63S1717D20345201141E 
/01E31E2331010t66488570E94828l2307DF669201503043472FF3D67346EFF709B3B5B 
/02031 107700FA2FF644A08BS04FFFF34D000403D13E1 

/02141E160167072017023A0307FD636C44000040000C346CFF71800040210C636603FD 

/02321E164E1D3471FF3567203475FF2436FF2C3F2C22482A48314S314831709E3F2A7A 

/02301El63B40a8026C0338S86C01147EOF5F0314i90F380214020F6DEE69ED6419083E 

/026ElE257079128q4829707D12806409F36419040S03FB44030040EFOBB8703F83FF4C 

/028C1E2369334OCBOB71800F3466FF4O210C34S3FF4883691O704114OO0S74E044103D 
/02AA041A064893B831 

/02AEIE29407BOCB8407BOC6406FE6AFF40CE026A0040CE026406FFB86406FF6930348C 
/02CC1E29F301340000693340CBOB2428804400080A3A3274FFFB340000693140CBOB1E 
/02EA1E29242BS044000S2A2A60FA4FD03274FFF7SS407BOC403D136406FE340000444C 
/03081E1A0020690070933274FFFA633F6406FF6700B8693134F30140780C33Q201B847 
/03261E1A690834F30144030040000C71S003346EFF3367203472FF40210C69ED707937 
/03441E1A128040020FBQ407BOC44000040000C718000349BFF4FE2407BOC440700400E 
/0362 1 E1AEFOB 69EF7079 1 2S04OO20F34 A4FF7 1 800740 1 1 OC 0 1 A4634S0 1 A363470 1 A640 

/03S01E1A634901AB370C690B63S7408A1301A71801AB1934320174EF44C8004BA4343A 

/039E1E294AFF4B93BB407BOC44FF0140C30B340000703E7AFF69EF40D60B40020FB8B4 

/03BC1E29407BOC44FF0140C50B703F7AFF69ED40D60B40020FBB713ES0402AOC409F80 

/03DA1E290F40EDOC717604402C1240F41240E30D146004701E9DFF6409FE3B3A64193D 

/03F81E29014843006407F7340003693140E40B6906707920S0636D40680E4EI 1644916 

/04161E1A014EOC6409FE30764FC16901S4F50140750S71811071390071760A69316A2D 

/04341E1A0240160740680ECF67004E04644901C76409FE30764FE6203930814FDDB83E 

/04321EIA402A0C409F0F40DB0340070EB8F8C0C0B0401713483A690740E1146409FE33 

/04701D194017137069228037F06407FFAOAA62407BOC036BF83C024E877176043443 

/048D1E28A000703E85FF40AEOCD3406705F83502QS4E2E1S020S40A7150S02F7B84047 

/04AB1E287414405708400014703F3DFFA7340000703E3BFF74EFB83076CXC8409FOF6B 

/04C91E28402C124FBE40380340741414FBFF408305346009703EB5FF40491235A5C04C 

/04E71 E28C 640670 5F54E224049 120 1 A474B8A5C640670SF34E134074 1 4 1 4FFFF408 338 

/OS031E190S402C12407414400014B80302EF403805014C38SSC66900393869FF634F32 

/03231E19014C355801C669FF39386900633014F6FF408303B80302F034200340AC114C 

/0341lEl96700DOl3020240E01140390340E011403903B86903347E002038033e0301E4 

/053F1D2730583S014F6336B8716700716A1471690140F2083483FF4883691470612C 

/037C1B24489314000074EDB9B8440000343BFF4S95A34893400014409FOFB820 

/03971E24402AOC409FOF719B0044FF0140720840900869336A1940160740680EC3402A 

/03B31E242E07C1F045030S40020F703F7AFF69ED40D60B3081C440020FB840FEOD346B 

/03D31E24780C017B1604637B4FCC402AOC409FOF4403027366E344030240720840902F 

/05F11E24OB69336A0940160740680ECS4O2EO7C1FO45O3OS4002OF7O3F7AFF69ED4O4F 

/060F 1 E24D60B 308 1 C 440O20FB 840FE0D34780C 0 1 7B 1 604637B 4FC C 402 AOC 409F 0F7 1 67 

/062D1E249B0044FF0140720840906869336A1940160740680EC3402E07C1F03081C127 

/064B1E24B840FEOD347BOC4FE4402AOC409FOF44FF0140720840900834000069EF4039 
/066902 1 7D60B 1 E 

/066B 1 E264 0020F693 1 6 A0240 1 607308 ICC 40680EB S402EO7B 87 181 00EA703F7SFF744B 
/0689 1 E26 1 604703E78FF69EF40D60B 40680EC C 402E07C 8693 1 6 A0240 1 607F00 1 7B 1 6 6 3 
/06A71E2604637B40FEOD34780C4FB9402AOC409FOF4403027366E64403024072084040 
/06C31E26900834000069EF40D60B40020F69316AOA4016073081CC40680EBB402E072C 
/06E31E26B871S100EA703F78FF741604703E78FF69EF40D60B40680ECC4Q2E07CS69A1 
/O7011E17316A0A4O1607FO017B16O4637B40FEOD347B0C4FB97O3F7AFF4OE4OB342164 
/071F1E26B04B0101 39707927800 A3 33 B 63 6DB B6409FE67004E3370 1 E7DFFOB 67004 E6 1 
/073D1E261E57704E3374SA044E2E743A084E2F743A10D6S704D337024E3S743A03D162 
/073B1E26CE63660AC47366E6B8691F6912691C691D691E691430764E34C840AE0CC79E 
/07791E266910691934F3017069248074F837D37069238074F836CB70692680071F7436 
/0797 1 E26E8384FD33076C 469 1 34FDB403708409F0F402C 1 2B96366E3B 86366F3334B9 3 
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/O7B3XE26480O6406FE70iF;i'AFF44000274C7B7693X4QCB0B348AFF7X8Q0540XX0COX53 

/07D3XE26B77-4BS9BCXD4348AFF2490FF6A032070FAC82252F9X303X04E2X34SAFF249A 

/07FXXE2690FF6B033X407C X76 406FF30774FAa0503EF0X8774BB9BC369XX54F30X7072 

/080FXE263F7AFFA7703F96FF74C7B7B3693X40CBOB34A4FF7X800240XXOCOXA47490S9 

/082DXD239863A40XA374909963A50XA674909A63A6A3693340CB0B34A4FF7Xe00254 

/084AXE23402XOC7X6E98X303047XSXOOBa706E24S0706F2580A77069268007034BA420 

/0868XE23482X704X343DFF4S93BB40C30B3429804B33324BOE3424800X373DOX363D36 

/OS86XE230X383B690270792280BS3478FF44000048934893XS0308308X003490FF6A2A 

/08A40A200369003D52FD40330EBB76 

/08AEXE2F3468FF69FC70FDC9690A70FDC4483A70FBD70X02XA409BOCOA74E3Q2C847AD 

/08CCXE2FXOC36906347EOOX50302Ba0303FD54F30X590354F30X54DD055903S4F30X23- 

/08EAXE2F54B206390354F30X402AOCOX6A633BX3020243690X0302FD3303a034620902 

/0908lE201302046901433802C3483A0302FB330202CA4a3AlA0102160463020A74COOI 

/0926XE2056635640X7X30X4C74E056450204483A74B04C4EXF403AX474EB584EX7633b" 

/09441E2058344FFFS33801324CC074E0374333024a3A70C36336303B4FAA40F412Ba63 

/0962XE200X3B330202483A74C03X635X4059X84059X8Ba590334F30X408B09440XOOOX 

/0980XE2040000C7XaOOX3485FF4E8369004DCC44FFFF48D24B450034AD09703EAOFF83 

/099EXE2F40A4X2700E7DFF350208FF40X7X3FC69044DCC700F7DFF34C809703EAOFFAX 

/09BCXE2F40A4X2AA5S0208FF40X7X3FC4aC03485FF4S93700F7 i DFF40DOX2AABa59037C 

/09DAXE2F34F30X440X0040000C7X800X345FFF4E2344FF0740C50B34000069E040D62B 

/09F8XE2FOB40020FB8590354F30X44FF0040000C7180FF3400FF402XOC69ED7079X240 

/OAX6XE2G8040020FB8590354F30X44EF0040EFOB69EF7079X28040020F3400FF7X8046 

/QA341E2QEF401XOCB8590354F30X4Q2AQC40D40C7181XX7X7A007X7BOOX4620A70XEXF 

/0 A52 X E209DFF484300700E7DFF6407F740 X 7X3FC700F7DFF6407FFAA69003 X FE6 A03B2 

/OA70XE2040E30C0070XE7DFFOX7BXEOX7A4604XF4602637A693340CBQB347DFF7X8065 

/OA8EXE2FOl402XOC30aX4FD8446B0040C30B340000703E7AFF69ED40D60B4002QFB843 

/OAAC X E2F 590354F30 X402AOC409FOF44470040C30B34000369EF40D60B 40020F34DE38 

/OACAXE2F03390334F30X402AOC64XAa040E50D6409FE7069208Q690670792080403D27 

/OAE8XE2FX34017X3643AXOF9640A7FB8390334F301402AOC40E30D342COB703E9DFF3C 

/OB06XE204843006407F76409FE69067079208040X7X37069228047FOF6690070792029 

/OB24XE20806407FF6409FEB8B0690740EXX4483A483AC064X90X40X7X340X7X340X732 

/OB42XE20X37069228047FOA409FEAOAA62390334F30X402AOC40E30D34870B703E9D52 

/OB60XDXFFF64X90X4843006407FT6906707920a040X7X37069228047FOF6690070XA 

/OB7DXE2E7920806407FF6409FEB8B0690840EXX4C0006409FE690640EX14C06900004A 

/OB9BXE2E&4t90XAOAA62590334F30X402AOC4049X2440X0040000C7X800X34A4FF40F9 

/0BB90C2B2X0C69ED7079X28040020FB883 

/OBC3XE2B340Ae04S93BaA7240C8048927079X380BeA72408B04S927079X2800303F73A 

/OBE3XE2BB8A72400a048927079X080B840C30B340003693X40CBOB69EE40D60BB84043 

/0C0XXE1CC30B3400O3693340CB0B69EE4OD60BBB4O020F0X80XB2428B02A002A3DS333 

/0CXFXE2BFCB8242B802D3A30S0FBB8346EFF3S67S03472FF69803B407B0C6409FE3498 

/OC30XE2B36FF4B8370XF47FF74B04E2F08670369FFX82D07XF74BB494E2X07034aA49E 

/0C3BXE2B482X4836704X2D37XXD30A070X3D4S934O900C55O302B834630274AFBS692C 

/OC79XE2B2XD0356720CC3S020SC8636600BB5802FDB8690434F50X370XC46409FDBS6X 

/0C97XE2B64X9O2BB6480OB690640EXX44CE00S02EF3780X502XOBB40D40C7X7FX26A33 

/OCB3XE2B8340E30CC76700D0743B30CC706B27a0744BFFC440750aB8307FE440730870 

/OCD3XE2BB93429804B33324B07690270792280BB693340X60740680EB8B9692033&A3C 

/OCFX XE2B X 14F977i7F0940D40C690040CC44FFFF48D2X4XaOD70XE9DFF484300700E9 X 

/ODOFXE2B7DFF6407F740X7X3FC69044DCC700F7DFF6407FFAA7XaX007X7DXX40X7X33A 

/0D2DXE2B34870048C074AFFB44FA00Ca4SC074AFFB44900X74C7B7B36A85693340X684 

/0D4B 1E2B07A3644AXOC748C074AFF74E26706920B057304E2470692780A7X X4EXC204A 

/0D691E2B8X658X124E266B0S4OX7X353FB44FDOX74C7B74FBB2420804A002A757DXX4C 

/0D87XE2BC60XaX637D4FDA3O7F4F687X7DX13400O369334OCB0B34D4OD0X6AACXC6B6A 

/ODA3XE2B00703F36FFA70X38XD6A00342880083B093BOD74983E3BOX7D60FEC34BXX60 

/00C3XE2BC90A3B60C437 X X66X X XA43747B X24FEOBa0XOX09O60DO703OSOF02OC0EOA23 

/ODEXXE2B040BOai069037079228069X270792X803429804BX0324BOE70692080BS4004 

/ODFFXE3A330E20397339XXB97X39000X384X74Ea496900633a7079268Q7700D6343622 

/OEXDXE2BFF4aS3A848?37Q3F47FF74EFB83424a0083D093DOX3A4X67026900633A406D 

7:OE3BlE2B900C7700B9343DFF4aa3A8343BFF*4a93346S0274EFB8409FOFB«m7703S392 

/OE39XE2B6B407X77007X7603336B807X7600Ba5303804E8D4CC0637C6A03583B6AOX40 

/0E77XD2A0A4DC87X7D307X7E09690440EXX40A644AX04E5E4DC84CE0644AX04ES55F 

/OE94XE2A74EO36644AXO4E40355aO2483A644AXO4E4374CO374DCO644AXO4E39396D3C 

/OEB2XE2ADF644AX04E3X66X0483A644AX04E2874C07C644AX04E2026E064X90X644A40 

/OEDOXE2AXOD730704FAF644AXOCF307E4FA769007079208070XF2080B969FF70XF2073 

/0EEEXE39806439OXB9747B00B96900B84OX7X3643AX0F9E738O24EB7SSO3804E736C32 

/0F0CXE2A0338386C0X0C4DC869O34OEXX4643AO44E30OC64SA044E2A4DC84CE0643A62 

/0F2AXE2A044E2X74E036643A044EX9353a02483A643AO44E0F74C037643A044E074D3O 

/OF48XE2AC0644A044FCB644A20BBOC644A20B84DC84CE06'44A20B874E056644A20B879 

/OF66XD29353802483A644A20BB74C037644A20E84DC0645A204FDXB840X7X3644A43 

/OF83XC2704F940X7X3643A20F9B8643A04C33802F94F70&44A20B83802F94F6733 

/0F9FXE364ODa0F3802FDBa402A0C3F6BC44Q9F0FB84OXXO2346BO0703E9DFF64O7EF8F 

/OFBDXE3640D80F3802C8BA644A08C734DB00643AOaFX04FFFFAA40940X4FEa403BX3B9 

/QFDBXE366409EF40CCX3243BFF4884703F4AFF64X92074BF6409DFB3746AFF64X920AS 
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/OFF9lE364e84701E3DFF74EDBS74E30aS78O4E0A0302FD7X3BC07X5C40CFX4FFFF74B6 

/XOX7XEX893A8X302027X3B407XSCCOX3030X0303DF0502FEB440S6X3A4436B074E3E39 

/X033XEX8X40X0074AD4E4448A04894B348XAX22443FF3447XB4SA4488E4894A348A462 

/X053XEX848SE4892X370XE4XFFXXX4EOX02400003439XAXX6900S90269FF4DC0699639 

/X07XXDX74DDA64S39064S380484100640FFDB80X3B4DC0699F40EXX4XX3443XAX44D 

/X08EXE262FX9XX4FDC3400007X3D06B348224S330X3D482X60AB460X60BB660X370A27 

/XOACXE26690A270469044823633D40EOXX69015902483A74C03S0703633SOX305838X8 

/X0CAXE260X4F6336A974FF4FC64039X84096X340F4X2X3020XB84CC20703XA4822603A 

/XOEB1E26926339X4FFX03502023X00070374F85QX4EOX032XOXX620X39XB4CC20703FA- 

/XX06XEX7XA48226092633960E33902483A0703747C00483A60432B60E3747C00483A30 

/XX24XEX74400006480004780D74B3AXS4SA04SA03902D30XSB704XOS6700C369FFD834" 

/XX42XEX709D61848A048A03902EBOX3B706XOS67FFC36900C309483A4DC0747C004E68 

/XX60XEX72270XF43FFA374FFD80X3F60E374C04XXDOX5C635B6CFF703F43FF14FFXOA2 

/XX7EX7XFX0XX6232F8449CXA74AFCA743D03C6X42FX9X0XX6233E6FE 

/XX93XEXF4CC074A063206463632063B80X646337690063636364B8X30280703E96FF34 

/XXB3XEXF7X3D0240EOXX77004EXF690X5902483A74C038070363SaOX30SS5BOX4F63XA 

/XXDXXEXF3630964FE030974FDC690003027FBSOX5D59384B3A3302024B3A74C0566353 

/XXEFXE2E3640X7X3SF02CB4CC074E0S74630269F4E284074X40XS038380X4F74E04C43 

/X20DXEXF355802483A350202483A27S04FCS055803403D1474EB584FBA6900BS69FF6X 

/X22BXEXFB8SC02B834ESX6703EAOFF0303DF40A41240X7133003FA64XF2040DOX2B837 

/X249XEXF0502FB3464X2703EAOFF40A4X240X7X33A02FA40DOX2AA40X7X3B8BOBX4C36 

/X267XEXFCXXA7566F007FD4DCX690240EXX440B2X20A4DCX484300AXAOAA6264ao094X 

/X283XEXF690640EXX44CE063A469004B3ACOC0648009690440EXX44CE063A3X302042A 

/X2A3XEXFB84CC757XODC249DFF488214660074BDC4444700CXA307F7BA48924DC74898 

/X2CXXEXF4300AAB8703E9DFF484300640FF7BS4CC73710DB249PFF4S82X466O074BD9B 

/X2DFXE2EC4444CO0C3446B0OX7O8BA48924DC7AABS64XFOSB87X7FFF7X82OA4CCb6389 

/12FDXE2E3A307FC36904347E0040X7X34CC074E05A460326F5E43082E8B83F03D76466 

/X3XBXEXF80000X3i63S2X4000070XE33FF690840EXX440DFXBB8403DX3690340EXX40D 

/X339XEXF404BX3B86406FF383SC4648003BS64800XB84CE074E0565358024B3A74C03B 

/X337XEXF374DCOB8206X236XX7BB7X6X006A032062CXDXOX626AOC6740CA6A30678029 

/X373XEXFC36AC060FABB343XFF7X7F040A708B60EA4E080A482X608A70C33B32307F79 

/X393XEXF4FEC8B40SA14403DX463380X3038380X4F633670XF3BFF40A8X4XA70BB603B 

/X3BXXEXFEA402CX2B8406AX440S7X9633X70XF3BFF40BCX4342CFFAD6337B870XF3D86 

/X3CFXE2EFFA33C02D93D03D64074X44099X40X4FBD420X30BDB340ASX4X6FF70883B73 

/X3EDXE2EBS40BCX4342CFF0X37BD6900636363646365BSOX3D0703XB702F4FFF746B6F 

/X40BXEXF00CB0C1A0D4057X4XC0AXD53FX6BX33404FF003D0C3DXA0DXC0A4037X4XD36 

/X429XEXF33F26B040X373D53FD69FF6B043D33FDBS4074X47X7DO0OX3O74AS4F7X7D7A 

/X447XDXE034037X46A0274884F6A030A749070BSB4BX70XF4CFF6AOOA34SA4706XSA 

/X464XEXEB30B746AOOC76900742AB069FFAXA4Ba64S000690440EXX44CE0634F69043A 

/X482XEXE40EXX44CEX6330B870XF3BFF4099X4AD634F42AD6330B840BC1448264a266F 

/ X4A0 1 EX E60 X A48263404FFB840BC X 46B033 X C8343 X FF0A60470BB848274827F X 0B073D 

/X4BEXE2D03746AFF1400004B274Q36B84S3A4S3AC0B0696X40EXX4A0C03X34CAX4BB4S 
/ X 4DC0A2S483A4B3AC 05 X 54DC X 4BS7E 

/X4E6XE284S440034X08069303D3D69EE3D3269053B6409F364X90444050040EFOB7X36 
/X504XEX99C347X9D6B7X9E007X9F346407EFAA7X0300242B80345DX36B0C3X3423805X 
/X322XEX94BOX242980346AXSX42E807X7DOOOX7D3A2039X22039X3207DSC7DF2706940 
/X340XEX9208034330X703E47FF7X490434900X703E4AFF7XB70B7X9B00408A15BS0337 
/ X 33EXE2SCADB000018X82S0A0CB80000CA3302000AFF0 1FF0X 33O4O002O0O3FF0AFF2A 
/ X 57C X E280 XFFO X 530000060002FF09330 X 337 X S9FF3488FF0 X 872707C 34B 0032660829 
/X39AXE28XA69FF746AOOC44S2X32F83BBS300XD340DOX20302F67XOX0364X94040B933 
/X3B8XE28X640940XF969806337634C690O6367636B6363636363647X40AE7X4EXE6432 
/X3D6XE2B00806409BF409BOC3302X04E2334FFFF40C6I6403AX463380X30383BOX4F3D " 
/ X 3F4 X E28633640F4 X 234320OO3O2FD4OAC XXX 6FF63SF64006071 900 X7X9X9E7X 92FF37 

/X6X2XEX940B91640940X3092F7309XF43090EB34A04X40C6X6X302206400987X76040B 
/X630XEX94CC20703XA4CC2070360EAF9XA3076F37X3X807X38007X36804059X80X4C32 
/X64EXE2a634F7X3000X4900X036BFa40830340F4X240F4X240X7X34093XX3363FFF6XB 
/X66CXE2S0302FD7X3DOX40EOXX7X3B030X4F74C0304B3X634E40EOXX7X3S020X4F630D 
/X6BAXE2B3640EOX17X380XOX4F74C030483X634D74C04E483X634C633640F4X240F426 
/X6A8XE28X240B91640940X4082047X6E007XOX03B8643FXOC3644A08BaB9000000B90E 
/X6C6XE2B703E96FF7X7F0X40B9X640940X408B09703F83FFA7703F96FF4S4374BFE69E 
/ X 6E404 X D307FE6B 840 

/ X 6E8 1 E2C64O9FD484300AABOB X B43C024E6F690040E X X 4747200C 04082 X20 X 3A409029 

/X706XEXD0C44A04X406BX740X7X3OXA474C0A3483XXA274X4E3FOXA4433DOXOXA344X3 

/X724XEXDOOOOX848A048A048A040X7X36406FE6900CX4X70624BOAFA6406FF6620432C 

/X742XEXD3B024B3A74C036633640DOX240F4X2484300703FAOFF40A4X2XS0320403BX4 

/X760XCXBX3A4AXA0620X3A40900CF04SD269004DCC484S0069044DCC640FDFBS3X 

/X77CXE2A4408X0OX8AXA0X8BXB0X8CXC0XBD1DOX8EXE0X8FXF747AO0DX0BXA0CXBOD48 

/X79AXE2AXCOEXDOFXE6F006908704XEB097700C30867004EBDA9482248330C483XXC3A 

/X7B8XE2A0D4B3XXD0E4B3XXE0F4 83t XF4a0AD274X28C74X30C74X4QA74X 32874X6X839 

/X7D6XE2A74X7080A6090609E609F77004FC20B7408684FBCOC7408894FB6094707COA9 
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/17F4XE2A48230C483XXC0D4S3XXDA94FEF48A048A048A03496FF48V50B3D0CriD0D3P8A 
/lBX2XEXB6A080B403FXSCA0C403FXSC5OD4O3FXa00OAXF6A2O0D404CX8CA0C404CXS3S 
/XB30XEXBC30B404CXSOOOA60E7639BB869FFFA7X7D0748234BXAB842307DF7B97X7D97 
/184E0B26074a21481ABS323070F7B9Sa 

/1S39XE260302FE0303FE44FFFF406BX764S00069CS4DDA648S9064B5S0484X00640F70 
/18771E26FD11148218X143O2O1FCBBO131633271330O7154OO03O2FB71820AO13263F8 
/1S93XE26SAX49CXBXOXX6240DFX80X5274E03A460A26EBE63082EAX302047X820A7X34 
/X8B3XE265500X4BBX8XXX06240DFX874E037460S26F37XS20A3082EA64XF22X3Q20XXA 
/ 1SD 1 XE263803E X 4096 X340F4 X 264 X 9 X 04FD640BD X 9648O0O X C3432FF2B60E4 XB6A0Q3D 
lE3357806AFFOC3D4Ba374C54a9SSAnpnAnc?7nrnq7anrQf5-7*aff^i*iA«-riL ^ - 



' * ww * * *-cw w w ww w * -rw / w AWTwr -» * «to*t 47* w**r uonUo u i Y<b4dUUO X C3432FF2B60E4 XB6 A0Q3D 
/1BEFIE3357806AFFOC3D4BS374C34B933A02D60970C33780C8273FCC20376640C73784 
/X90DXE26CXC4305746403BOX374SA4704X086700CD2780C369004DCOB869FF4DCOB867 
/ X92B XE26O94DC0B8B340BDX964S00O&332A369CS4DDAA73438X A74E7B748A474C74B8B * 
/ X 949 X E26 A048A04S A434AF XD74C7B 70 X 3 X 74E032330202483 A X D6C0044FFFF4O6B X 767 
/X967XE264E48B340BDX9648000A3XA74E032330202483A37804F04A67Q6X3648XAF74A 
/ X9e3 X E260A63 324S8374E60 X 3C3902CA704X B 30B747A0069FFCB706 XB50B433A747A6D 

/X9A3XE26FF69004DC0333344AFXD74EF4FCBX469X9XXX0620X301BOX4FC34CEXXB4C72' 

X9C X 1 WAW^CDi T*-T/irm/i r+ ^ « a «*tr-i-r ~ — 



♦ evw^uMwwj^Ttnriu/«ttr^ruHi^fl7lvil X0620X301B0X4FC34CEX XB4C72 
-r * ^ w * X E26E034FB XD74B04C4E36X AOB74S04CD6602ACC440000 X84B3EAE6640483ABB79 
/X90F1E336BOOA3483DAEB8483A602ACA440000X84S3EAE4640B86BOOA34Q3DAE66S077 
/X9FDXE33483AB8483AXAOB74B04CD6602ACA44000OXS483EAE6640BS6B00A3483DAE79 
'1AXBXD23483ABS4S3A602ACC440000X8483EAE66C0483ABS6BOOA3483DAE4680B872 
> r XA3eXE2300O000O000O0OO00QOOO0O0O0OO000000XOXOX0XOX0X0202020202030303X9 
/XA36XE25030404O4040SO30306060607O707O8OS08O9O90A0A0B0B0B0C0C0DOD0E0EF6 
/XA74XE230F0FX0X01iXXX2X213X4X4X5XSX6X7X7X819X9XAXBXBXCXDXDXEXF202O2XEA 
/1A92XE25222323242326262728292A2B2C2C2D2E2F303X3233343336363738393A3B XO 1 
'1AB0XE253C3D3E404X42434443464748494A4B4D4E4F303XS2545S56375S5A5B3C5D63 
/XACEXE345F606X6364636668696A6C6D6F707X737473777a7A7B7D7ES08X8384868790 
✓ XAECXE34898A8C8DBF9092939597989A9B9D9FA0A2A4ASA7A9AAACAEB0BXB3B5B7B8FA 
/XBOAXE2SBABCBQFCXC3C3C7C9CACCCEOOD2O4D60aDA0BDDDFEXE3E3E7E9EBEDEFF176 
XXB28XE23F3F3F7F9FBFD000204060SOAOCOEXOX3X317X9XBXE20222426295B2D2F324B 
/XB46XE25343BXA48XA4EXA33XAS7XA3BXA3EXA6XXA64XA67XA69XA6BXA6EXA70XA7263 
/XB64XE23XA74XA76XA78XA7AXA7CXA7DXA7FXAaXXAB2XA84XAa3XA87XA88XA8AXA8B8A 
/XB82X7XEXA8DXA8EXA8FXA9X1A92XA93XA9SXA96XA97XA99XA9AXA39 

/XB99XE2D9BXA9CXA9DXA9EXAA0XAAXXAA2XAA3XAA4XAA3XAAwXAA7XAABXAA9XAABXAAX 
/XBB7XE2DAC XAADX AAEX AAFXABOXAB X 1 AB2XAB3XAB3XAB4XAB3X AB6XAB7XABBXAB9XAAC 
/XBD3XS27BAXABBXABCXABDXABEXABFXABFXAC0XACXXAC2X AC3XAC4XA7X 
/XBEDXE36C3XAC3XAC6XAC7XAC8XAC9XACA1ACAXACBXACCXACDXACEXACEXACFXADOXAE3 
/XC0BXE27DXXADXXAD2XAD3XAD4XAD3XA031AD6XAO7XAI>8XADaXAD9XADAXA0AXADBXAC2 

/XC4FXE2FE9XAEAXAEAXAEBXAECXAECXAEDXAEEXAEEXAEFXAFOXAFOXAFXXAF2XAF2XAF9 

' x "* 1e ^ 3i a^*af4xaf3x^^ 

/XC8BXE2FFC1AFOXAFDXAFEXAFFXAFFXA0OXBOOXBOXXB02XB02XBO3XBO3XB04XBO4XB6D 
/XCA9X22303XB06XB06XB07XB07XB08XB08XB09XBGAXBAE w^b^iwb 

/XCBBXE32OAXBOBXB0BXB0CXB0CXBODXB0EXBOEXBOFXBOFXBXQXBXOXBX XXBX XXBX2XB3C 

/XCD9XE32X2XBX3XBX4XB14XBXSXBX3XBX6XBX6LBX7XBX7XBX8XBX8XBX9XBX9XBIAXB20 
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Having thus described an embodiment of the 
invention, it will now be appreciated that the ob- 
jects of the invention have been fully achieved in 
realizing a completely self contained, compact, 
modular plug-in disk file subsystem, and it will be 
understood by those skilled in the art that many 
changes in construction and widely differing em- 



bodiments and applications of the invention will 
suggest themselves without departing from the 
spirit and scope of the invention. The disclosures 
and description herein are purely illustrative and 
are not intended to be in any sense limiting. 
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The features disclosed in the foregoing de- 
scription, in the following claims and/or in the ac- 
companying drawings may, both separately and in 
any combination thereof, be material for realising 
the invention in diverse forms thereof. 



Claims 

1. A modular unitary disk file subsystem for 
use within a housing of a host computer, said 
subsystem comprising a common unitary mounting 
substrate including signal connection means 
formed along a single connection edge of said 
substrate for enabling direct plug in attachment and 
connection of the disk file subsystem to the data, 
address and control buses of said host without 
cabling, said connection means for obtaining con- 
trol and data signals from said host computer, and 
for supplying control and data signals back to said 
host computer, said substrate carrying and inter- 
connecting a fixed rotating disk assembly including 
a radially positionable head transducer for flying in 
close proximity to a data storage surface of at least 
one rotating data storage disk upon an air bearing, 
disk store control means for controlling the radial 
position of the head transducer in relation to the 
data storage surface, disk file controller means for 
controlling the storage and retrieval of useful data 
to and from the storage surface via the head trans- 
ducer, and interface means for enabling the disk 
file subsystem to connect directly to and be used 
with the host computer. 

2. The modular unitary disk file subsystem set 
forth in claim 1 wherein said signal connection 
means enable direct plug in attachment and con- 
nection to the power buses of said host without 
cabling. 

3. The modular unitary disk file subsystem set 
forth in claim 1 wherein said disk store control 
means and said disk file controller means are both 
supervised and operated by a single programmed 
digital microcomputer. 

4. The modular unitary disk file subsystem set 
forth in claim 1 wherein said interface means fur- 
ther comprises a read only memory containing 
prestored basic input/output routines suitable for 
being directly accessed and executed by a central 
processing unit of said host computer thereby en- 
abling said subsystem to. be installed in said host 
computer and used thereby without need to add 
such routines to the host operating system control 
program. 

5. A modular unitary disk file subsystem for a 
host computer, said subsystem comprising: 

a thin, compact and enclosed radially movable 
head and fixed rotating disk assembly and, 



support means for mounting and supporting said 
head and disk assembly and for mounting, carrying 
and connecting electronic circuit elements for mov- 
ing said head relative to said disk, 

5 

said electronic circuit elements for controlling data 
storage operations for storing and retrieving data 
from among selected concentric data tracks formed 
on a data storage surface of said fixed rotating disk 
io through said head, and for interfacing said disk file 
subsystem with said host computer, 

said support means further including connection 
means along a single connection edge thereof, said 
75 connection means for obtaining power, control and 
data signals from said host computer, and for sup- 
plying control, status and data signals to said host 
computer, 

20 said support means thereby carrying and intercon- 
necting said subsystem with said host computer as 
a direct plug-in unit within the housing of said host 
computer, without any cabling between the host 
and the subsystem. 

25 6. The modular unitary disk file subsystem set 

forth in claim 5 wherein said support means com- 
prises a frame and a small printed circuit board 
attached to said frame, said circuit board carrying 
substantially all of said electronic circuit elements 

30 and carrying said connection means. 

7. The modular unitary disk file subsystem set 
forth in claim 5 wherein said support means com- 
prises a unitary printed circuit board for mounting 
said head and disk assembly and for carrying 

35 substantially all of said electronic circuit elements 
and said connection means. 

8. A modular unitary disk file subsystem for a 
host computer, said file comprising: 

40 a common unitary mounting substrate for said sub- 
system, 

disk store means supported by said substrate and 
including: 

45 

at least one non-removable data storage disk being 
rotatable relative to said substrate, disk rotation 
means for rotating said disk at a predetermined 
angular velocity relative to said substrate, at least 

so one data transducer held in close proximity to a 
major data storage surface of said disk by air 
bearing effect, transducer actuator means including 
support means for said transducer moveably 
mounted to said substrate, said actuator means for 

55 causing said transducer to be moved among avail- 
able ones of concentric data tracks formed on said 
major surface during track seek operations and for 
maintaining said transducer in alignment with a 
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selected data track during track following oper- 
ations, 

said substrate further supporting: 

disk store control means connected to said ac- 
tuator means, said disk store control means includ- 
ing servo means responsive to track centeriine 
position information indicative of transducer posi- 
tion relative to a centeriine of any of said data 
tracks over which the transducer may be posi- 
tioned for reading and writing of data to and from 
said surface and further responsive to command 
signals for causing said actuator to move said 
transducer radially relative to said surface during 
track seeking operations and for causing said ac- 
tuator to maintain said transducer in an alignment 
position relative to said data surface during track 
following operations, 

disk file controller means connected to said disk 
store control means and to said transducer, said 
controller means for receiving data files from said 
host computer, for reformatting said files for stor- 
age onto said surface in accordance with a pre- 
determined data format, for converting digital data 
to and from analog format suitable for transduction 
by said transducer to and from said data surface, 
and for generating and applying track seeking com- 
mands to said disk store control means during 
track seeking operations and for generating and 
applying read/write commands to operate said tran- 
ducer during data following operations, 

interface means and being connected to said host 
computer and to said disk file controller means for 
interfacing said subsystem to said host computer, 
and 

a single programmed digital microcomputer con- 
troller for supervising and controlling operations of 
said disk store means and said file controller 
means. 

9. The modular unitary disk file subsystem for 
a host computer as set forth in claim 8 wherein 
said disk store means comprises a unitary assem- 
bly detachable and disconnectible by plug and jack 
connections from said substrate. 

10. The modular unitary disk file subsystem for 
a host computer as set forth in claim 9 wherein 
said disk store control means, said disk file control- 
ler means, said interface means and said single 
programmed microcomputer controller are substan- 
tially entirely formed on a single printed circuit 
board which is detachable from said disk store 
means by plug and jack connections. 



1 1 . The modular unitary disk file subsystem for 
a host computer as set forth in claim 10 wherein 
said substrate comprises a frame for mounting said 
disk store unitary assembly and said single printed 

5 circuit board. 

12. The modular unitary disk file subsystem for 
a host computer as set forth in claim 10 wherein 
said substrate is formed by said printed circuit 
board. 

10 13. The modular unitary disk file subsystem for 

a host computer as set forth in claim 8 further 
comprising a memory containing prestored basic 
input/butput routines suitable for being directly ac- 
cessed and executed by a central processing unit 
75 of said host computer thereby enabling said host 
computer to use said subsystem without software 
modification of the host operating system. 

14. The modular unitary disk file subsystem for 
a host computer as set forth in claim 8 wherein 
20 said substrate is adapted for mounting said sub- 
system as a single component directly within the 
housing of said host computer, said substrate pro- 
viding power and signal connection means along a 
single connection edge for engaging complemen- 
ts tary power and data, address and control signal 
connection means of said host computer directly 
for thereby obtaining electrical power, and ex- 
changing control signals and data with said host 
computer. 

so 15. The modular unitary disk file subsystem for 

a host computer as set forth in claim 8 wherein 
said servo means includes an optical encoder for 
generating polyphase position information between 
said rotary actuator means and said substrate. 

35 16. A modular unitary disk file subsystem for 

direct plug-in attachment to and use with a host 
personal computer within a housing thereof, said 
subsystem comprising a common unitary mounting 
substrate for providing physical attachment of the 

40 subsystem to the housing inside the personal com- 
puter and signal connection means along a single 
connection edge of said substrate, said connection 
means for obtaining control and data signals from 
data, address and control lines of said host com- 

45 puter, and for supplying control and data signals 
back to said host computer, said substrate carrying 
and interconnecting a head and disk assembly 
including at least one rotating storage disk and a 
data transducer head moveable among concentric 

so data tracks formed on said disk, disk store control 
means for controlling the position of the transducer 
head relative to the data tracks, disk file controller 
means for controlling the transfer of useful data 
between the subsystem and the host personal 

55 computer, and interface means enabling direct 
plug-in attachment to the host personal computer 
and use therewith via the signal connection means. 
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17. The modular unitary disk file subsystem set 
forth in claim 16 wherein said interface means 
further comprises a read only memory containing 
prestored basic input/output routines suitable for 
being directly accessed and executed by a central 5 
processing unit of said host personal computer 
thereby enabling said subsystem to be installed in 
said host personal computer and used thereby 
without need to add such routines to the host's 
operating system control program. 10 



18. The modular unitary disk file subsystem set 
forth in claim 16 wherein said disk store control 
means and said disk file controller means are both 
supervised and operated by a single programmed 
digital microcomputer.— 

1 9. The modular unitary disk file subsystem set 
forth in claim 16 comprising two rotating data stor- 
age disks and four data transducer heads, there 
being a said transducer head in close proximity to 
each data storage surface.— 



75 



20 



25 



30 



35 



40 



45 



50 



55 



29 



0 204 299 




0 204 299 




0 204 299 




0 204 299 




0 204 299 




0 204 299 




0 204 299 



o 



BACK EMF 



FIG. 8a 




GND 



+ 12 V 



INDEX 



Vcc 



353 



@— I STOP/START 
<3) INJECTOR 



p — | | ®H OSC IN 

□ ,0p (s) MODE SELECT 

AA/vC ©— I OSC OUT 

I.8K 1 

(7) GND 

« ,o (D— 1 I REF. 
0.22 i 

+ <9) FILTER 

<J0) — I SPEED DISCR. 
1 OUT 
([]) CURRENT 
T 1 



_ . SOURCE 
]t+ \ ^ f Q2) — I INTEGRATOR IN 

OUT 

INTEGRATOR OUT 
V OUT 
®-H N.C. 

<I7)W OUT 
<gH W HALL -IN 
<J9)W HALL +IN 
-f — (gQH V HALL -IN 
<2j)v HALL +IN 
@— I U HALL -IN 



3)U HALL +IN 



355—^J. 



202 



ROTOR COIL 307 



CO 
CM 

< 



0 204 299 



264 




270 260 



FIG. 8b 



0 204 299 




0 204 299 



FIG. 12 











!> L> 

1 




r— 1 


FIG. 




1 n E 

i i 


•**\ 
— / 


U| 


K> 
Q 








uj"wJ 






412 



41 5-*, 



41Z 



n»»-i 



421^1 



419 



423- 



♦ 

K> 



O 
I * 

K) 



425 ' — ' I — 

V V V V V t 



-383 



O 204 299 




0 204 299 




0 204 299 



A A A A 



373 

J. 
®- 

®- 

0- 

G> 



.1 



400 

\ 



'HI < £2 

■^-i </> < 



8 

CM 



CM 




SERVO AMI 




r u. ° B 5 w * 

(£222 — Otf>oO<K 



10 

■AAAr 



519 



CM 




r 



375 



■vw 

4.7K 



X 



.1 



2SC3232 



0 204 299 



AAA am 



— v r' 



433- 



DISABLE SW 



HEAD SEL 

CLR busy; 



^6 J 



5j 



INC RD TH 
R.W.C. 



READY , 



SEEK/S 



DPI 



DP2 



DMA INT 



BUSY 



JIJ 



J 3) 



16; 
Ll9) 



7810 



SEQ INT 



REQ 



2IJ 



WR UNSAFE, 



WT PRECOMP, 



INDEX. 



2.2K 



I Op 



12MHz 



H 

I Op 



(3i; 



PA0 
PA I 
PA2 
PAS 
PA4 
PA5 
PAS 
PA7 
PB0 
PBI 
PB2 

PB3 JJfil 

PB4 

PB5 

PBS 

PB7 

PC0 

PCI 

PC2 

PC3/INT2 

PC4 

PC5 

PCS 

PC7 

JM 

INT I 

MODE I 

RESET 

MODE 0 

X2 

XI 

V3S 



Vce 
Vdd 
PD7 
PD6 
PD5 
PD4 
PD3 
PD2 
PDI 
PD0 
PF7 
PF6 
PF5 
PF4 
PF3 
PF2 
PFI 
PF0 
ALE 

m 
ray 

AVcc 
V4ref 
AN7 
AN 8 
AN5 
AN4 
AN3 
AN2 
AN I 
AN0 
AVss 



— 439- 



.60 



MAI5 



LSI) 



K7> 



435- 



437 



AAAA 




■5» 
■5"- 



FIG. I2e 



0 204 299 




(N 



o 

CM 
CM 



K X 

- o 




\ 





0 204 299 





0 204 299 



> 



CN 



Hi" 



ii 




ftn\ 



1 OflOOyijOLjrNggJfO I 





2 

Q. 



CM N - - 

o >c o 

O Ul O UJ 

< QC < Q£ 



"7 



m 





I 



0 204 299 



> 



(N 



Hi" 



Hi" 



r 
I 

L 




(0 in t fo 
o 



I <<<<<<<<oooo 




to 



M 
X 




_ o o 
5 ^ oc 



H N N o < 
2 <£ OC OS O LJ 

< 5 z z > os 



O O 



fO CM — 

< < < _ 

O O O O.- 

(/></> v5 m < 




I 



YY 



V Y Y V Y 



Y Y 



> 



Y Y 



0 204 299 




CD O 



wsO 



RDx O 
RDy O 



WDI O- 



HSI O 
HS2 O 
HS3 O 



386 



VCT 

O 



CHIP 




SELECT 


1 



US 

o 



WRITE 
SELECT 



READ 
EN 



POST 
READ 
AMPLIFIER 



HEAD 
SELECT 



CURRENT 
SOURCE 



Owe 



WRITE EN 



UNSAFE 
CIRCUIT 
DETECTOR 



DIFFERENTIAL 
READ 
AMPLIFIERS 
AND 
WRITE 
CURRENT 
SWITCHES 

(6 CHANNELS) 



HEAD 0 



HEAD I 



HEAD 2 



HEAD 3 



HEAD 4 



HEAD 5 



FIG. 13b 



-O H0I 
O Hflf2 

-Ohii 

OHI2 

-OH2I 
-OH22 

-OH3I 
-OH32 

-OH4I 

-OH42 

hOhsi 

-0H52 




FIG. 13c 



320, 322 



0 204 299 



467 




HOST 
INTER- 
FACE 



A 



413 



SERIAL/ 
PARALLEL 
CONVERTER 



465 



CRC/ECC 



.463 



J\ REGISTERS/ /L 
/ CONTROL V 

^ N 



471 

_z 



I MICROPROCESSOR 
1 INTERFACE 



461 
473 

Z 



EXTERNAL 
REGISTER 
INTERFACE 



FIG. 14 



V 



DISK 
INTER- 
FACE 



469 



INPUT/ 
OUTPUT 
INTER- 
FACE 



Y 1 
v 



ADDRESS 
GENERATOR 



■^-483 



Y 1 
v 



REGISTERS/ 
CONTROL 
LOGIC 



475 



479- 



DATA 
SEQUENC- 
ER 
INTER- 
FACE 



I 



417" 



MICROPROCESSOR 
INTERFACE 



FIG. 15 



I 



-481 



0 204 299 



22 j,s) 




0 204 299 




TO 
1246 



P2 



VREF 



TO 124 
SUB- 
STRATE 



JI03-I 



RI5 



470K 



RI3-^4.7K 



CHIP 
470K IM POT 



- J 1 03— 5 



J 1 03— 4 



TO 
I24C 



AGC 




142 




R7 



FIG. 18 



-i 



Jl-I 
TO LED 118 
LEO CATHODE 

JI-2 



330K 



R6 

CHIP 
IM POT 




0 204 299 




0 204 299 



o 
O 



! 



CO 

z 

or 

z 

UJ 

O 
UJ 
CO 



MARK 




PRE- 
INDEX 
GAP 


* 


K> 


in 


HOLD 




USAGE 


AM 
SEARCH 
RESTART 

PAD 




X 




INTER- 
SECTOR 
GAP 
















INDE 




o 


K) 

fO 




LOOP 




:tor ga 


SPEED 
TOLER- 
ANCE 


in 


















w 

1. 1 






IPDATE 


DATA 
POST- 
AMBLE 


fO 


fO 

ro 


i j 






INTER-SI 


WRITE 
UPDATE 
LOSS 


ro 


SECTOR 


Si 


DATA 
ECC 


<0 


AS 

REQ'D 










POSE: 


BYTES 


URING \ 


DATA 
FIELD 


m 


rO 
rO 


_ 






a. 


Li. 

O 


a 


















8 BYTES PER 


-WRITTEN 


DATA 

MARKER 

BYTE 




00 

u. 


O 








SECTOR 




UJ 

QC 


fk ATA 

DATA 
SYNC 
BYTE 




<N 

<© 


o> 






FIELD BREAKDO* 


HEAD 




RS 56 




DATA 
PRE- 
AMBLE 




It 


CO 






CYLIN- 
DER 
LOW 




. SECTO 




ID 

POST- 
AMBLE 


lO 


ro 
ro 








a 
i— i 


CYLIN- 
DER 
HIGH 




ITICAL 




•=5 ui 




AS 
REQ'D 


CO 








\NING: 


IYTES: 


8 IDEh 




ID 

DATA 
FIELD 




AS 
REQ'D 


to 








UJ 


UJ 

U. 

o 






Ul 




















ID 

MARK 
BYTE 




li! 








DOWN 


INDEX 
DRIFT 












CM 
<0 


ro 






IREAK 




















UJ 






MARK 22 




ID 

PRE- 
AMBLE 




t: 


CM 


RESTART 




MDEX GAP 


SERVO 
WEDGE 




INDEX 




1 

INDEX 
GAP 




ro 
ro 




START 




POST II 


RPOSE: 


BYTES: 


FIELD 


SEQ- 
CNT 


1 

UJ < 
CO > 


SEQ- 
STATE 


UJ 

o 
o 
25 




a. 


u. 
o 



z 

O 

z 

CO 

>- 
m 

9 



O 
CN 

O 



